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FIELD OF INVENTION 
The present invention relates to communications in computer networks. More 
specifically, it relates to a method and system for dynamic service registration in a data-over- 
cable system. 

5 BACKGROUND OF THE INVENTION 

Cable television networks such as those provided by Comcast Cable Communications, 
Inc., of Philadelphia, Pennsylvania, Cox Communications of Atlanta, Georgia, Tele- 
communications, Inc., of Englewood Colorado, Time- Warner Cable, of Marietta Georgia, 
Continental Cablevision, Inc., of Boston Massachusetts, and others provide cable television 
10 services to a large number of subscribers over a large geographical area. The cable television 
networks typically are interconnected by cables such as coaxial cables or a Hybrid Fiber/Coaxial 
("HFC") cable system which have data rates of about 10 Mega-bits-per-second ("Mbps") to 
about 30+ Mbps. 

The Internet, a world- wide-network of interconnected computers, provides multi-media 
15 content including audio, video, graphics and text that typically requires a large bandwidth for 
downloading and viewing. Most Internet Service Providers ("ISPs") allow customers to connect 
to the Internet via a serial telephone line from a Public Switched Telephone Network ("PSTN") 
at data rates including 14,400 bps, 28,800 bps, 33,600 bps, 56,000 bps and others that are much 
slower than the about 10 Mbps to about 30+ Mbps available on a coaxial cable or HFC cable 
20 system on a cable television network. 

With the explosive growth of the Internet, many customers have desired to use the larger 
bandwidth of a cable television network to connect to the Internet and other computer networks. 
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Cable modems, such as those provided by 3Com Corporation, of Santa Clara, California, 
Motorola Corporation, of Arlington Heights, Illinois, Hewlett-Packard Co., of Palo Alto, 
California, Bay Networks, of Santa Clara, California, Scientific-Atlanta, of Norcross, Georgia 
and others offer customers higher-speed connectivity to the Internet, an intranet, Local Area 
5 Networks ("LANs") and other computer networks via cable television networks. These cable 
modems currently support a data connection to the Internet and other computer networks via a 
cable television network with a data rate of up to about 30+ Mbps, which is a much larger data 
rate than can be supported by a modem used over a serial telephone line. 

However, many cable television networks provide only uni-directional cable systems, 
10 supporting only a "downstream" cable data path. A downstream data path is the flow of data 
LI from a cable system "headend" to a customer. A cable system headend is a central location in 

W the cable television network that is responsible for sending cable signals in the downstream 

^ direction. A return data path via a telephone network (i.e., a "telephony return"), such as a 

Li public switched telephone network provided by AT&T, GTE, Sprint, MCI and others, is 

II 15 typically used for an "upstream" data path. An upstream data path is the flow of data from the 
fS customer back to the cable system headend. A cable television system with an upstream 

connection to a telephony network is called a "data-over-cable system with telephony return " 
An exemplary data-over-cable system with telephony return includes customer premise 
equipment (e.g., a customer computer), a cable modem, a cable modem termination system, a 
20 cable television network, a public switched telephone network, a telephony remote access 

concentrator and a data network (e.g., the Internet). The cable modem termination system and 
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the telephony remote access concentrator together are called a "telephony return termination 
system." 

The cable modem termination system receives data packets from the data network and 
transmits them downstream via the cable television network to a cable modem attached to the 
5 customer premise equipment. The customer premise equipment sends response data packets to 
the cable modem, which sends response data packets upstream via public switched telephone 
network to the telephony remote access concentrator, which sends the response data packets back 
to the appropriate host on the data network. 

In a two-way cable system without telephony return, the customer premise equipment 
10 sends response data packets to the cable modem, which sends the data packets upstream via the 
M- cable television network to the cable modem termination system. The cable modem termination 

W system sends the data packets to appropriate hosts on the data network. The cable modem 

%4 termination system sends the response data packets back to the appropriate cable modem. 

J~ As a cable modem is initialized in a data-over-cable system, it registers with a cable 

il 15 modem termination system to allow the cable modem to receive data over a cable television 
ffi connection and from a data network (e.g., the Internet or an Intranet). The cable modem 

forwards configuration information it receives in a configuration file during initialization to the 
cable modem termination system as part of a registration request message. A cable modem also 
helps initialize and register any attached customer premise equipment with the cable modem 
20 termination system. 

A cable modem termination system in a data-over-cable system typically manages 
connections to tens of thousands of cable modems. Most of the cable modems are attached to 
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host customer premise equipment such as a customer computer. To send and receive data to and 
from a computer network like the Internet or an intranet, a cable modem and customer premise 
equipment and other network devices have a network address dynamically assigned on the data- 
over-cable system. Many data-over-cable systems use a Dynamic Host Configuration Protocol 
5 ("DHCP") as a standard messaging protocol to dynamically allocate network addresses such as 
Internet Protocol ("IP") addresses. As is known in the art, the Dynamic Host Configuration 
Protocol is a protocol for passing configuration information to network devices on a network. 
The Internet Protocol is an addressing protocol designed to route traffic within a network or 
between networks. 

% 10 A cable modem termination system typically handles requests for services on the data- 

Mi: over-cable system cable modems and customer premise equipment. As is known in the art, a 
W Multimedia Cable Network System ("MCNS") Data Over Cable Service Interface Specification 
%4 system ("DOCSIS") is typically used on some data-over-cable systems to define server interfaces 

that allow data services on a session basis. A session based data service is typically provided to 
il 15 a network device such as a cable modem or customer premise equipment during a one-time login 
ffj and registration. The data service is typically available, or "always on," as long as the network 

device is powered on. 

A Remote Authentication Dial In User Server ("RADIUS") server one is one example of 
an interface used by the DOCSIS system to provide data or other services to a network device. 
20 As is known in the art, RADIUS servers are responsible for receiving user connection requests, 
authenticating users, and then returning configuration information necessary for a client to 
deliver a service to a user. A RADIUS server can act as a proxy client to other RADIUS servers 
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or other kinds of authentication servers (e.g., a Voice over Internet Protocol server, Dynamic 
Host Configuration server, a cable modem termination system, etc.). 

Data services and other services such as Voice over Internet Protocol ("VoIP"), 
Asynchronous Transport Mode ("ATM"), Frame Relay, Integrated Services Digital Network 
5 ("ISDN"), Asymetric Digital Subscriber Lines ("ADSL") with configurable Quality-of-Service 
("QoS"), Class-of-Service ("CoS"), Type-of-Service ("ToS"), etc. parameters are typically also 
session based. When a network device desires a data or other service, a DOCSIS system server is 
typically used to provide authentication, authorization and/or accounting for assigning a data 
service used by a network device during a service session. 
10 There are several problems associated with using a DOCSIS system server or other non- 

H= DOCSIS to allow a data service during a session on a data-over-cable system. A session is 
W typically created once during a login and registration sequence, and not changed as long as the 
^ network device is "powered on." For example, for Voice over Internet Protocol, a network 

m device would typically require a session where a voice call could be completed at any time. One 

15 solution is to allow a network device that requires a session to have a maximum number of 
eg service parameters and service resources allocated to the session whether or not the network 

device is actually using a requested service. However, this may waste services resources on the 
data-over-cable system and prevent other network devices from using resources that are 
allocated, but are not currently being used by a network device. 
20 It is also typically necessary to provide authentication, authorization or accounting at a 

DOCSIS system server or other non-DOCSIS when a service session is created. If a requested 
service requires additional service agreements, additional authentication, authorization or 
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accounting has to be completed. However, the authentication, authorization or accounting is 
typically associated with a login request to initiate a service session. So requesting additional 
services after a service session is established may prevent authentication, authorization or 
accounting from being properly used by current DOCSIS system servers or other non-DOCSIS 
5 servers and may compromise the security of the data-over-cable system or prevent the data-over- 
cable system from collecting revenues it is owed for providing access to a service. 

Thus, it is desirable to dynamically provide service session based services after a session 
has already been established by a network device. The dynamic service session based services 
should provide the ability to activate session-based services and also allow authentication, 

S 10 authorization or accounting to be dynamically used after a session has already been established 

y~ by a network device. 
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SUMMARY OF THE INVENTION 
In accordance with preferred embodiments of the present invention, some of the 
problems associated with providing dynamic service session based services in a data-over-cable 
5 system are overcome. A method and system for providing dynamic service registration on a 
data-over-cable system is provided. One aspect of the present invention includes a method for 
providing dynamic session services in a data-over-cable system. The method includes receiving a 
first message on a second network device on a data-over-cable system from a first network 
device on the data-over-cable system. The first message includes multiple service parameters for 
% i o a desired service for a service device associated with the first network device. The multiple 
U service parameters for the desired service are extracted from the first message. A service session 

W profile is created for the desired service. The service session profile includes one or more of the 

H extracted service parameters required by the desired service. The service session profile is used 

K by a service server associated with the second network device to activate the desired service. 

U 15 The service session profile is associated with a deferred inactive service identifier for the first 
1 network device. The deferred inactive service identifier is used to activate the desired service at a 

later time. The deferred inactive service identifier is returned to the first network device in a 
second message. 

Multiple deferred inactive service identifiers can be returned to support multiple service 
20 devices associated with a first network device requesting multiple services. The deferred 
inactive service identifier is used at a later time by a service device associated with the first 
network device to activate the desired service and to generate a service event on a service server. 
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A desired service can be dynamically activated even though the first network device may have 
already established a session (e.g., a login or other session) with the second network device on 
the data-over-cable system. A desired service that has been activated using a deferred inactive 
service identifier can also be dynamically deactivated and reactivated again at a later time. 

5 For example, the method allows a first network device, such as cable modem, to receive a 

deferred inactive service identifier during a registration sequence with a second network device, 
such as a cable modem termination system, that can be used by a service device (e.g., a voice 
over internet protocol telephone) associated with the cable modem to activate a desired service at 
a later time when the service device is ready to use the desired service (e.g., for a Voice over 

10 Internet Protocol call). The service session profile includes parameters required to by the desired 
service (e.g., quality-of-service parameters). The deferred inactive service identifier is also used 
to generate a service event on a service server associated with the cable modem termination 
system (e.g., an authentication, authorization or accounting event on a Voice over Internet 
Protocol server). The desired service can be dynamically activated even though the first network 

15 device may have already established a session (e.g., a login) with the second network device on 
the data-over-cable system. 

However, the present invention is not limited to cable modems, cable modem termination 
systems and Voice over Internet Protocol services. Other network devices and other desired 
services can also be used with the method. 

20 Another aspect of the present invention includes a system for providing dynamic services 

to a network device in data-over-cable system. The system includes a network device for 
providing a desired service requested by a service device. A service session profile includes one 



-9 



MCDONNELL BOEHNEN 
HULBERT & BERGHOFF 
300 SOUTH WACKER DRIVE 
CHICAGO, ILLINOIS 60606 
TELEPHONE 13121 913-0001 



or more of the service parameters required for a desired service. A deferred inactive service 
identifier associated with a service session profile allows activation of a desired service at a later 
time. A deferred active service identifier created from a deferred inactive service identifier 
indicates that a desired service is now active. A service event generator generates a service event 
5 on a service server associated with a network device to request a change in status of a desired 
service on a data-over-cable system. 

The method and system may dynamically provide deferred session based services after a 
service session between a network device and a data-over-cable system has already been 
established. The dynamic session based services may also provide the ability to allow service 

m 10 events such as authentication, authorization or accounting to be dynamically generated when a 

p deferred session based service is activated or deactivated. 

W The foregoing and other features and advantages of a preferred embodiment of the 

present invention will be more readily apparent from the following detailed description, which 
ft ] proceeds with references to the accompanying drawings. 
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BRIEF DESCRIPTION OF THE DRAWINGS 
Preferred embodiments of the present invention are described with reference to the 
following drawings, wherein: 

5 FIG. 1 is a block diagram illustrating a cable modem system with telephony return; 

FIG. 2 is a block diagram illustrating a protocol stack for a cable modem; 
FIG. 3 is a block diagram illustrating a Telephony Channel Descriptor message structure; 
FIG. 4 is a block diagram illustrating a Termination System Information message 
structure; 

10 FIG. 5 is a flow diagram illustrating a method for addressing hosts in a cable modem 

SI system; 

kj FIG. 6 is a block diagram illustrating a Dynamic Host Configuration Protocol message 

JE structure; 

f FIGS. 7 A and 7B are a flow diagram illustrating a method for discovering hosts in a 

Lr; 15 cable modem system; 

FIG. 8 is a block diagram illustrating a data-over-cable system for the method illustrated 
in FIGS. 7Aand7B; 

FIG. 9 is a block diagram illustrating the message flow of the method illustrated in FIGS. 
7A and 7B; 

20 FIGS. 10A and 1 OB are a flow diagram illustrating a method for resolving host addresses 

in a data-over-cable system; 
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FIG. 1 1 is a flow diagram illustrating a method for resolving discovered host addresses; 

and 

FIG. 12 is a block diagram illustrating the message flow of the method illustrated in FIG. 

10; 

5 FIGS. 13 A and 13B are a flow diagram illustrating a method for obtaining addresses for 

customer premise equipment; 

FIGS. 14A and 14B are a flow diagram illustrating a method for resolving addresses for 
customer premise equipment; 

FIGS. 15A and 15B are a flow diagram illustrating a method for addressing network host 
10 interfaces from customer premise equipment; 
yi FIGS. 16A and 16B are a flow diagram illustrating a method for resolving network host 

W interfaces from customer premise equipment; 

FIG. 17 is a block diagram illustrating a message flow for the methods in FIGS. 15 A, 
J 15B, andl6Aandl6B; 

JT is FIG. 18 is a flow diagram illustrating a method for dynamic service registration on a 

m data-over-cable system; 

FIG. 19 is a block diagram illustrating a registration message sent from a cable modem to 
a cable modem termination system; 

FIG. 20 is a block diagram illustrating a registration response message sent from a cable 
20 modem termination system to a cable modem; 

FIG. 21 is a flow diagram illustrating a method for dynamic service activation on data- 
over-cable system; and 
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FIG. 22 is a flow diagram illustrating a method for dynamic service deactivation on data- 
over-cable system. 
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DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 



Exemplary data-over-cable system 

FIG. 1 is a block diagram illustrating an exemplary data-over-cable system 10. Most 
5 cable providers known in the art predominately provide uni-directional cable systems, supporting 
only a "downstream" data path. A downstream data path is the flow of data from a cable 
television network "headend" to customer premise equipment (e.g., a customer's personal 
computer). A cable television network headend is a central location that is responsible for 
sending cable signals in a downstream direction. A return path via a telephony network 
10 ("telephony return") is typically used for an "upstream" data path in uni-directional cable 
U systems. An upstream data path is the flow of data from customer premise equipment back to 

W the cable television network headend. 

'" 4 However, data-over-cable system 10 of the present invention may also provide a bi- 

directional data path (i.e., both downstream and upstream) without telephony return as is also 
iu 15 illustrated in FIG. 1 . The present invention is not limited to a data-over-cable system with 
fn telephony return. In a data-over cable system without telephony return, customer premise 

equipment or a cable modem has an upstream connection to the cable modem termination system 
via a cable television connection, a wireless connection, a satellite connection, or a connection 
via other technologies to send data upstream to the cable modem termination system. 
20 Data-over-cable system 10 includes a Cable Modem Termination System ("CMTS") 12 

connected to a cable television network 14, hereinafter cable network 14. FIG. 1 illustrates one 
CMTS 12. However, data-over-cable system 10 can include multiple CMTS 12. Cable network 
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14 includes cable television networks such as those provided by Comcast Cable 
Communications, Inc., of Philadelphia, Pennsylvania, Cox Communications, or Atlanta, 
Georgia, Tele-Communications, Inc., of Englewood Colorado, Time-Warner Cable, of Marietta, 
Georgia, Continental Cablevision, Inc., of Boston, Massachusetts, and others. The cable network 
5 14 is connected to a Cable Modem ("CM") 16 with a downstream cable connection. The CM 16 
is any cable modem such as those provided by 3Com Corporation of Santa Clara, California, 
Motorola Corporation of Arlington Heights, Illinois, Hewlett-Packard Co. of Palo Alto, 
California, Bay Networks of Santa Clara, California, Scientific- Atlanta, of Norcross, Georgia 
and others. FIG. 1 illustrates one CM 16. However, in a typical data-over-cable system, tens or 
10 hundreds of thousands of the CMs 16 are connected to the CMTS 12. 
ji The CM 16 is connected to Customer Premise Equipment ("CPE") 1 8 such as a personal 

W computer system via a Cable Modem-to-CPE Interface ("CMCI") 20. 
%l One CPE 18 is illustrated in FIG. 1. However, the CM 16 may have multiple CPE 18 

« J attached (Not illustrated in FIG. 1). In one preferred embodiment of the present invention, the 

il 15 CM 16 is connected to a Public Switched Telephone Network ("PSTN") 22 with an upstream 
03 telephony connection. The PSTN 22 includes those public switched telephone networks 

provided by AT&T, Regional Bell Operating Companies (e.g., Ameritech, U.S. West, Bell 
Atlantic, Southern Bell Communications, Bell South, NYNEX, and Pacific Telesis Group), GTE, 
Sprint, MCI and others. The upstream telephony connection is any of a standard telephone line 
20 connection, Integrated Services Digital Network ("ISDN") connection, Asymmetric Digital 
Subscriber Line ("ADSL") connection, or other telephony connection. The PSTN 22 is 
connected to a Telephony Remote Access Concentrator ("TRAC") 24. 
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In another preferred embodiment of the present invention, in a data-over cable system 
without telephony return, the CM 16 has an upstream connection to the CMTS 12 via a cable 
television connection, a wireless connection, a satellite connection, or a connection via other 
technologies to send data upstream outside of the telephony return path. An upstream cable 
5 television connection via cable network 14 is illustrated in FIG. 1 . 

FIG. 1 illustrates a telephony modem integral to the CM 16. In another embodiment of 
the present invention, the telephony modem is a separate modem unit external to the CM 16 used 
specifically for connecting with the PSTN 22. A separate telephony modem includes a 
connection to the CM 16 for exchanging data. In yet another embodiment of the present 
10 invention, the CM 16 includes functionality to connect only to the cable network 14 and receives 
y* downstream signals from the cable network 14 and sends upstream signals to the cable network 
m 14 without telephony return. The present invention is not limited to cable modems used with 
^ telephony return. 

In one preferred embodiment of the present invention of the telephony return, the TRAC 
LI. 15 24 is a Total Control Telephony Hub by 3Com Corporation of Santa Clara, California. An 
J exemplary TRAC 24 is described in U.S. Patent No. 5,528,595, granted to Dale M.Walsh et al., 
and incorporated herein by reference. However, the TRAC 24 could also be a telephony hub 
including those by Lucent Technologies of Murray Hill, New Jersey, Livingston Enterprises, Inc. 
of Pleasanton, California, Ascend Communications of Alameda, California and others. 
20 The CMTS 12 and the TRAC 24 may be at a "headend" of cable system 10, or the TRAC 

24 may be located elsewhere and have routing associations to the CMTS 12. The CMTS 12 and 
the TRAC 24 together are called a 'Telephony Return Termination System" ("TRTS") 26. The 
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TRTS 26 is illustrated by a dashed box in FIG. 1 . The CMTS 12 and the TRAC 24 make up the 
TRTS 26 whether or not they are located at the headend of cable network 14. The TRAC 24 may 
be located in a different geographic location from the CMTS 12. Content severs, operations 
servers, administrative servers and maintenance servers used in data-over-cable system 10 (not 
5 shown in FIG. 1) may also be in different locations. Access points to the data-over-cable system 
10 are connected to one or more of the CMTS 12, or cable headend access points. Such 
configurations may be "one-to-one", "one-to-many " or "many-to-many," and may be 
interconnected to other Local Area Networks ("LANs") or Wide Area Networks ("WANs"). 
The TRAC 24 is connected to a data network 28 (e.g., the Internet, an intranet or other 
3 10 LAN) by a TRAC-Network System Interface 30 ("TRAC-NSI"). The CMTS 12 is connected to 
|i data network 28 by a CMTS-Network System Interface ("CMTS-NSI") 32. The present 
W invention is not limited to data-over-cable system 10 illustrated in FIG. 1, and more or fewer 
" components, connections and interfaces could also be used. The present invention may also be 

fjl used in a data-over-cable system 10 with or without telephony return. 

l& 15 Network device protocol stack 

y3 FIG. 2 is a block diagram illustrating a protocol stack 36 for network devices in data- 

over-cable system 10. FIG. 2 illustrates the downstream and upstream protocols used, for 
example, in the CM 16. As is known in the art, the Open System Interconnection ("OSI") model 
is used to describe computer networks. The OSI model consists of seven layers including from 
20 lowest-to-highest, a physical, data-link, network, transport, session, application and presentation 
layer. The physical layer transmits bits over a communication link. The data link layer transmits 
error free frames of data. The network layer transmits and routes data packets. 
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For downstream data transmission, network devices including the CM 16 are connected 
to cable network 14 in a physical layer 38 via a Radio Frequency ("RF") Interface 40. In a 
preferred embodiment of the present invention, RF Interface 40 has an operation frequency range 
of 50 Mega-Hertz ("MHz") to 1 Giga-Hertz ("GHz") and a channel bandwidth of 6 MHz. 
5 However, other operation frequencies may also be used and the invention is not limited to these 
frequencies. The RF interface 40 uses a signal modulation method of Quadrature Amplitude 
Modulation ("QAM"). As is known in the art, QAM is used as a means of encoding digital 
information over radio, wire, or fiber optic transmission links. QAM is a combination of 
amplitude and phase modulation and is an extension of multiphase phase-shift-keying. QAM 
5 10 can have any number of discrete digital levels typically including 4, 16, 64 or 256 levels. In one 

embodiment of the present invention, QAM-64 is used in the RF interface 40. However, other 
W operating frequencies and modulation methods could also be used. For more information on the 
~ H RF interface 40 see the Institute of Electrical and Electronic Engineers ("IEEE") standard 802.14 
m for cable modems incorporated herein by reference. IEEE standards can be found on the World 

|I 15 Wide Web at the Universal Resource Locator ("URL") "www.ieee.org." However, other RF 
CO interfaces 40 could also be used and the present invention is not limited to IEEE 802.14 (e.g., RF 

interfaces from Multimedia Cable Network Systems ("MCNS") and others could also be used). 

Above the RF interface 40 in a data-link layer 42 is a Medium Access Control ("MAC") 
layer 44. As is known in the art, the MAC layer 44 controls access to a transmission medium via 
20 physical layer 38. For more information on the MAC layer protocol 44 see IEEE 802.14 for 
cable modems. However, other MAC layer protocols 44 could also be used and the present 
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invention is not limited to IEEE 802.14 MAC layer protocols (e.g., MCNS MAC layer protocols 
and others could also be used). 

Above the MAC layer 44 is an optional link security protocol stack 46. The link security 
protocol stack 46 prevents unauthorized users from making a data connection from cable 
5 network 14. The RF interface 40 and the MAC layer 44 can also be used for an upstream 
connection in a data-over-cable system 10 without telephony return. 

For upstream data transmission with telephony return, the CM 16 is connected to the 
PSTN 22 in physical layer 38 via modem interface 48. The International Telecommunications 
Union-Telecommunication Standardization Sector ("ITU-T", formerly known as the CCITT) 
5 10 defines standards for communication devices identified by "V.xx" series where "xx" is an 
H identifying number. ITU-T standards can be found on the World Wide Web at the URL 
"www.itu.ch." 

In one embodiment of the present invention, ITU-T V.34 is used as modem interface 48. 
m As is known in the art, ITU-T V.34 is commonly used in the data link layer for modem 

|i 15 communications and currently allows data rates as high as 33,600 bits-per-second ("bps"). For 
Cfi more information see the ITU-T V.34 standard. However, other modem interfaces or other 

telephony interfaces could also be used. For example, an Asymmetric Digital Subscribe Link 
("ADSL") or an Integrated Services Digital Network ("ISDN") telephony interface could also be 
used in place of the modem interface 48. 
20 Above modem interface 48, in data link layer 42, is a Point-to-Point Protocol ("PPP") 

layer 50, hereinafter PPP 50. As is known in the art, PPP is used to encapsulate network layer 
datagrams over a serial communications link. For more information on PPP see Internet 
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Engineering Task Force ("IETF") Request for Comments ("RFC"), RFC-1661, RFC-1662 and 
RFC- 1663, incorporated herein by reference. Information for IETF RFCs can be found on the 
World Wide Web at URLs "ds.mtermc.net" or "www.ietf.org." 

Above both the downstream and upstream protocol layers in a network layer 52 is an 
5 Internet Protocol ("IP") layer 54. IP layer 54, hereinafter IP 54, roughly corresponds to OSI 
layer 3, the network layer, but is typically not defined as part of the OSI model. As is known in 
the art, IP 54 is a routing protocol designed to route traffic within a network or between 
networks. For more information on IP 54 see, RFC-791, incorporated herein by reference. 

Internet Control Message Protocol ("ICMP") layer 56 is used for network management. 
3 10 The main functions of ICMP layer 56, hereinafter ICMP 56, include error reporting, reachability 
I- testing (e.g., "pinging") congestion control, route-change notification, performance, subnet 

y addressing and others. Since IP 54 is an unacknowledged protocol, datagrams may be discarded 

' :J and ICMP 56 is used for error reporting. For more information on ICMP 56 see, RFC-971, 

Q incorporated herein by reference. 

IT is Above IP 54 and ICMP 56 is a transport layer 58 with a User Datagram Protocol layer 60 

ffi ("UDP"), UDP layer 60, hereinafter UDP 60, roughly corresponds to OSI layer 4, the transport 

layer, but is typically not defined as part of the OSI model. As is known in the art, UDP 60 
provides a connectionless mode of communications with datagrams. For more information on 
UDP 60 see, RFC-768, incorporated herein by reference. 
20 Above the network layer are a Simple Network Management Protocol ("SNMP") layer 

62, Trivial File Transfer Protocol ("TFTP") layer 64, Dynamic Host Configuration Protocol 
("DHCP") layer 66 and a UDP manager 68. SNMP layer 62 is used to support network 
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management functions. For more information on SNMP layer 62 see, RFC-1 157, incorporated 
herein by reference. TFTP layer 64 is a file transfer protocol used to download files and 
configuration information. For more information on TFTP layer 64 see, RFC-1 350, incorporated 
herein by reference. The DHCP layer 66 is a protocol for passing configuration information to 
5 hosts on an IP 54 network. For more information on the DHCP layer 66 see, RFC-1 541, and 
RFC-2131, incorporated herein by reference. UDP manager 68 distinguishes and routes packets 
to an appropriate service (e.g., a virtual tunnel). More or few protocol layers could also be used 
with data-over-cable system 10. 

The CM 16 supports transmission and reception of IP 54 datagrams as specified by RFC- 
IS 10 791 . The CMTS 12 and the TRAC 24 may also perform filtering of IP 54 datagrams. The CM 
|i 16 is also configurable for IP 54 datagram filtering to restrict the CM 16 and the CPE 18 to the 

W use of only their assigned IP 54 addresses. The CM 16 is configurable for IP 54 datagram UDP 

~ 4 60 port filtering (i.e., deep filtering). 

!r. The CM 16 forwards IP 54 datagrams destined to an IP 54 unicast address across the 

[7 15 cable network 14 or the PSTN 22. Some routers have security features intended to filter out 
m invalid users who alter or masquerade packets as if sent from a valid user. Since routing policy 

is under the control of network operators, such filtering is a vendor specific implementation. For 
example, dedicated interfaces (i.e., Frame Relay) may exist between the TRAC 24 and/or the 
CMTS 12 which preclude filtering, or various forms of virtual tunneling and reverse virtual 
20 tunneling could be used to virtually source upstream packets from the CM 16. For more 
information on virtual tunneling, see Level 2 Tunneling Protocol ("L2TP") or Point-to-Point 
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Tunneling Protocol ("PPTP") in IETF draft documents incorporated herein by reference by Kory 
Hamzeh, et. al (IETF draft documents are precursors to IETF RFCs and are works in progress). 

The CM 16 also forwards IP 54 datagrams destined to an IP 54 multicast address across 
the cable network 14 or the PSTN 22. The CM 16 is configurable to keep IP 54 multicast 
5 routing tables and to use group membership protocols. The CM 16 is also capable of IP 54 
tunneling upstream through the telephony path. A CM 16 that wants to send a multicast packet 
across a virtual tunnel will prepend another IP 54 header, set the destination address in the new 
header to be the unicast address of the CMTS 12 at the other end of the tunnel, and set the IP 54 
protocol field to be four, which means the next protocol is IP 54. 
'% io The CMTS 12 at the other end of the virtual tunnel receives the packet, strips off the 

M encapsulating IP 54 header, and forwards the packet as appropriate. A broadcast IP 54 capability 
W is dependent upon the configuration of the direct linkage, if any, between the TRAC 24 and the 
^ CMTS 12. The CMTS 12, the CM 16, and the TRAC 24 are capable of routing IP 54 datagrams 

JT: destined to an IP 54 broadcast address which is across the cable network 14 or the PSTN 22 if so 

II 15 configured. The CM 16 is configurable for IP 54 broadcast datagram filtering. 
03 An operating environment for other devices, the CM 1 6 and other devices of the present 

invention includes a processing system with at least one high speed Central Processing Unit 
("CPU") and a memory system. In accordance with the practices of persons skilled in the art of 
computer programming, the present invention is described below with reference to acts and 
20 symbolic representations of operations or instructions that are performed by the processing 
system, unless indicated otherwise. Such acts and operations or instructions are sometimes 
referred to as being "computer-executed", or "CPU executed." 
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It will be appreciated that the acts and symbolically represented operations or instructions 
include the manipulation of electrical signals by the CPU. An electrical system with data bits 
causes a resulting transformation or reduction of the electrical signal representation, and the 
maintenance of data bits at memory locations in the memory system to thereby reconfigure or 
5 otherwise alter the CPU's operation, as well as other processing of signals. The memory 
locations where data bits are maintained are physical locations that have particular electrical, 
magnetic, optical, or organic properties corresponding to the data bits. 

The data bits may also be maintained on a computer readable medium including magnetic 
disks, optical disks, organic disks, and any other volatile or non- volatile mass storage system 
2 10 readable by the CPU. The computer readable medium includes cooperating or interconnected 
H computer readable media, which exist exclusively on the processing system or is distributed 
W among multiple interconnected processing systems that may be local or remote to the processing 
^ system. 

Initialization of a cable modem 
LI 15 When the CM 16 is initially powered on, if telephony return is being used, the CM 16 

m will receive a Telephony Channel Descriptor ("TCD") from the CMTS 12 that is used to provide 

dialing and access instructions on downstream channels via cable network 14. Information in the 
TCD is used by the CM 16 to connect to the TRAC 24. The TCD is transmitted as a MAC 44 
management message with a management type value of TRI_TCD at a periodic interval (e.g., 
20 every 2 seconds). To provide for flexibility, the TCD message parameters are encoded in a 
Type/Length/Value ("TLV") form. However, other encoding techniques could also be used. 
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FIG. 3 is a block diagram illustrating a TCD message structure 70 with MAC 44 management 
header 72 and Service Provider Descriptor(s) ("SPD") 74 encoded in TLV format. SPDs 74 are 
compound TLV encodings that define telephony physical-layer characteristics that are used by 
the CM 16 to initiate a telephone call. The SPD 74 is a TLV-encoded data structure that contains 
5 sets of dialing and access parameters for the CM 16 with telephony return. The SPD 74 is 
contained within TCD message 70. There may be multiple SPD 74 encodings within a single 
TCD message 70. There is at least one SPD 74 in TCD message 70. The SPD 74 parameters are 
encoded as SPD-TLV tuples. The SPD 74 contains the parameters shown in Table 1 and may 
contain optional vendor specific parameters. However, more or fewer parameters could also be 
2 10 used in the SPD 74. 



SPD 74 Parameter 


Description 


Factory Default Flag 


Boolean value, if TRUE(1), indicates a 
SPD which should be used by the CM 16. 


Service Provider Name 


This parameter includes the name of a 
service provider. Format is standard 
ASCII string composed of numbers and 
letters. 


Telephone Numbers 


These parameters contain telephone 
numbers that the CM 16 uses to initiate a 
telephony modem link during a login 
process. Connections are attempted in 
ascending numeric order (i.e., Phone 
Number 1 , Phone Number 2...). The SPD 
contains a valid telephony dial string as 
the primary dial string (Phone Number 1), 
secondary dial-strings are optional. 
Format is ASCII string(s) composed of: 
any sequence of numbers, pound "#" and 
star "*" keys and comma character 
used to indicate a two second pause in 
dialing. 


Connection Threshold 


The number of sequential connection 
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failures before indicating connection 
failure. A dial attempt that does not result 
in an answer and connection after no 
more than ten rings is considered a 
failure. The default value is one. 


Login User Name 


This contains a user name the CM 16 will 
use an authentication protocol over the 
telephone link during the initialization 
procedure. Format is a monolithic 
sequence of alphanumeric characters in 
an ASCII string composed of numbers 
and letters. 


Login Password 


This contains a password that the CM 16 
will use during authentication over a 
telephone link during the initialization 
procedure. Format is a monolithic 
sequence of alphanumeric characters in 
an ASCII string composed of numbers 
and letters. 


DHCP Authenticate 


Boolean value, reserved to indicate that 
the CM 16 uses a specific indicated 
DHCP 66 Server (see next parameter) for 
a DHCP 66 Client and BOOTP Relay 
Process when TRUE (one). The default is 
FALSE (zero) which allows any DHCP 66 
Server. 


DHCP Server 


IP 54 address value of a DHCP 66 Server 
the CM 16 uses for DHCP 66 Client and 
BOOTP Relay Process. If this attribute is 
present and DHCP 66 Authenticate 
attribute is TRUE(1). The default value is 
integer zero. 


RADIUS Realm 


The reaim name is a string that defines a 
Remote Authentication Dial In User 
Service ("RADIUS") server domain. 
Format is a monolithic sequence of 
alphanumeric characters in an ACSII 
string composed of numbers and letters. 


PPP Authentication 


This parameter instructs the telephone 
modem which authentication procedure to 
perform over the telephone link. 
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Demand Dial Timer 


This parameter indicates time (in 
seconds) of inactive networking time that 
will be allowed to elapse before hanging 
up a telephone connection at CM 16. If 
this optional parameter is not present, or 
set to zero, then the demand dial feature 
is not activated. The default value is zero. 


Vendor Specific Extensions 


Optional vendor specific extensions. 



Table 1. 



A Termination System Information ("TSI") message is transmitted by the CMTS 12 at 
periodic intervals (e.g., every 2 seconds) to report CMTS 12 information to the CM 16 whether 
5 or not telephony return is used. The TSI message is transmitted as a MAC 44 management 
C3 message. The TSI provides a CMTS 12 boot record in a downstream channel to the CM 16 via 
I y cable network 14. Information in the TSI is used by the CM 16 to obtain information about the 
;l 1 status of the CMTS 12. The TSI message has a MAC 44 management type value of TRIJTSI. 
%a FIG. 4 is a block diagram of a TSI message structure 76. TSI message structure 76 

10 includes a MAC 44 management header 78, a downstream channel IP address 80, a registration 
fU ip address 82, a CMTS 12 boot time 84, a downstream channel identifier 86, an epoch time 88 

'J? and vendor specific TLV encoded data 90. 

A description of the fields of TSI message 76 are shown in Table 2. However, more or 



fewer fields could also be used in TSI message 76. 



TSI 76 Parameter 


Description 


Downstream Channel 
IP Address 80 


This field contains an IP 54 address of 
the CMTS 12 available on the 
downstream channel this message 
arrived on. 


Registration IP Address 82 


This field contains an IP 54 address 
the CM 16 sends its registration 
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request messages to. This address 
MAY be the same as the Downstream 
Channel IP 54 address. 


CMTS Boot Time 84 


Specifies an absolute-time of a CMTS 
12 recorded epoch. The clock setting 
for this epoch uses the current clock 
time with an unspecified accuracy. 
Time is represented as a 32 bit binary 
number. 


Downstream Channel ID 86 


A downstream channel on which this 
message has been transmitted. This 
identifier is arbitrarily chosen by CMTS 
12 and is unique within the MAC 44 
layer. 


Epoch 88 


An integer value that is incremented 
each time the CMTS 12 is either re- 
initialized or performs address or 
routing table flush. 


Vendor Specific Extensions 90 


Optional vendor extensions may be 
added as TLV encoded data. 



Table 2. 



If telephony return is being used, after receiving the TCD 70 message and the TSI 



message 76, the CM 16 continues to establish access to data network 28 (and resources on the 



network) by first dialing into the TRAC 24 and establishing a telephony PPP 50 session. Upon 



5 the completion of a successful PPP 50 connection, the CM 16 performs PPP 50 Link Control 



Protocol ("LCP") negotiation with the TRAC 24. Once LCP negotiation is complete, the CM 16 



requests Internet Protocol Control Protocol ("IPCP") address negotiation. For more information 



on EPCP see, RFC-1332, incorporated herein by reference. During IPCP negotiation, the CM 16 



negotiates an IP 54 address with the TRAC 24 for sending IP 54 data packet responses back to 



10 data network 28 via the TRAC 24, via PPP 50. 



When the CM 16 has established an IP 54 link to TRAC 24, it begins "upstream" 



communications to the CMTS 12 via the DHCP layer 66 to complete a virtual data connection by 



attempting to discover network host interfaces available on the CMTS 12 (e.g., IP 54 host 
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interfaces for a virtual IP 54 connection). The virtual data connection allows the CM 16 to 
receive data from data network 28 via the CMTS 12 and cable network 14, and send return data 
to data network 28 via TRAC 24 and PSTN 22. The CM 16 must first determine an address of a 
host interface (e.g., an IP 54 interface) associated with on the CMTS 12 that can be used by data 
5 network 28 to send data to the CM 16. However, the CM 16 has only a downstream connection 
from the CMTS 12 and has to obtain a connection address to the data network 28 using an 
upstream connection to the TRAC 24. 

Addressing network host interfaces in the data-over-cable system 

FIG. 5 is a flow diagram illustrating a method 92 for addressing network host interfaces 
^ 10 in a data-over-cable system with telephony return via a cable modem. Method 92 allows a cable 
[l modem to establish a virtual data connection to a data network. In method 92, multiple network 
|jj devices are connected to a first network with a downstream connection of a first connection type, 
s 4 and connected to a second network with an upstream connection of a second connection type, 

if. The first and second networks are connected to a third network with a third connection type. 
I 15 At Step 94, a selection input is received on a first network device from a first network 

m over a downstream connection. The selection input includes a first connection address allowing 

the first network device to communicate with the first network via upstream connection to a 
second network. At Step 96, a first message of a first type for a first protocol is created on the 
first network device having the first connection address from the selection input in a first 
20 message field. The first message is used to request a network host interface address on the first 
network. The first connection address allows the first network device to have the first message 
with the first message type forwarded to network host interfaces associated with the first network 
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via the upstream connection to the second network. 

At Step 98, the first network device sends the first message over the upstream connection 
to the second network. The second network uses the first address field in the first message to 
forward the first message to one or more network host interfaces associated with the first 

5 network at Step 100. Network host interfaces associated with the first network that can provide 
the services requested in first message send a second message with a second message type with a 
second connection address in a second message field to the first network at Step 102. The 
second connection address allows the first network device to receive data packets from the a 
network via a network host interface available on the first network. The first network forwards 

10 one or more second messages on the downstream connection to the first network device at Step 
104. 

The first network device selects a second connection address from one of the second « 
messages from one of the one or more network host interfaces associated with the first network 
at Step 106 and establishes a virtual connection from the third network to the first network 
15 device using the second connection address for the selected network host interface. 

The virtual connection includes receiving data on the first network host interface on the 
first network from the third network and sending the data over the downstream connection to the 
first network device. The first network device sends data responses back to the third network 
over the upstream connection to the second network, which forwards the data to the appropriate 
20 destination on the third network. 

In one preferred embodiment of the present invention, the data-over-cable system is the 
data-over-cable system 10, with telephony return. In such an embodiment, the first network 
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device is the CM 16, the first network is the cable network 14, and the downstream connection is 
a cable television connection. The second network is the PSTN 22, the upstream connection is a 
telephony connection, the third network is data network 28 (e.g., the Internet or an intranet) and 
the third type of connection is an IP 54 connection. The first and second connection addresses 

5 are IP 54 addresses. However, the present invention is not limited to the network components 
and addresses described. Method 92 allows the CM 16 to determine an IP 54 network host 
interface address associated with the CMTS 12 to receive IP 54 data packets from the data 
network 28, thereby establishing a virtual IP 54 connection with the data network 28. 

After addressing network host interfaces using Method 92, an exemplary data path 

10 through cable system 10 is illustrated in Table 3. However other data paths could also be used 
and the present invention is not limited to the data paths shown in Table 3. For example, the CM 
16 may send data upstream back through the cable network 14 (e.g., the CM 16 to cable network 
14 to the CMTS 12) and not use the PSTN 22, the TRAC 24, or the telephony return upstream 
path. 



1 . An IP 54 datagram from data network 28 destined for the CM 1 6 arrives on the CMTS-NSI 32 
and enters the CMTS 12. 

2. CMTS 12 encodes the IP 54 datagram in a cable data frame, passes it to MAC 44 and 
transmits it "downstream" to RF interface 40 on the CM 16 via cable network 14. 

3. CM 16 recognizes the encoded IP 54 datagram in MAC layer 44 received via RF interface 40. 

4. CM 16 responds to the cable data frame and encapsulates a response IP 54 datagram in a 
PPP 50 frame and transmits it "upstream" with modem interface 48 via the PSTN 22 to TRAC 
24. 

5. TRAC 24 decodes the IP 54 datagram and forwards it via TRAC-NSI 30 to a destination on 
data network 28. 

15 Table 3. 

Dynamic network host configuration on a data-over-cable system 

As was illustrated in FIG. 2, the CM 16 includes a Dynamic Host Configuration Protocol 
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("DHCP") layer 66, hereinafter the DHCP 66. The DHCP 66 is used to provide configuration 
parameters to hosts on a network (e.g., an IP 54 network). The DHCP 66 consists of two 
components: a protocol for delivering host- specific configuration parameters from a DHCP 66 
server to a host and a mechanism for allocation of network host addresses to hosts. The DHCP 
5 66 is built on a client-server model, where designated the DHCP 66 servers allocate network host 
addresses and deliver configuration parameters to dynamically configured network host clients. 

FIG. 6 is a block diagram illustrating an exemplary DHCP 66 message structure 108. 
The format of the DHCP 66 messages is based on the format of BOOTstrap Protocol ("BOOTP") 
messages described in RFC-951 and RFC- 1542, incorporated herein by reference. From a 

5 10 network host client's point of view, the DHCP 66 is an extension of the BOOTP mechanism. 

H This behavior allows existing BOOTP clients to interpret with the DHCP 66 servers without 

requiring any change to network host the clients' BOOTP initialization software. The DHCP 66 

3 provides persistent storage of network parameters for network host clients. 

LH To capture BOOTP relay agent behavior described as part of the BOOTP specification 

[r% 15 and to allow interoperability of existing BOOTP clients with the DHCP 66 servers, the DHCP 66 
servers uses a BOOTP message format. Using BOOTP relaying agents eliminates the necessity 
of having a DHCP 66 server on each physical network segment. 

DHCP 66 message structure 108 includes an operation code field 110 ("op"), a hardware 
address type field 112 ("htype"), a hardware address length field 114 ("hlen"), a number of hops 
20 field 1 16 ("hops"), a transaction identifier field 118 ("xid"), a seconds elapsed time field 120 
("sees"), a flags field 122 ("flags"), a client IP address field 124 ("ciaddr"), a your EP address 
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field 126 ("yiaddr"), a server IP address field 128 ("siaddr"), a gateway/relay agent IP address 
field 130 ("giaddr"), a client hardware address field 132 ("chaddr"), an optional server name 
field 134 ("sname"), a boot file name 136 ("file") and an optional parameters field 138 
("options"). Descriptions for an exemplary DHCP 66 message 108 fields are shown in Table 4. 





DHCP 66 
Parameter 


Description 




AH A A f\ 

OP 110 


Message op code / message type. 

1 bUU 1 KtUUto 1 , £ — dUU 1 KtrLY. 




HTYPE 112 


Hardware address type (e.g., T = 10 
Mps Ethernet). 




HLEN 114 


Hardware address length (e.g. < 6' for 10 
Mbps Ethernet). 




HOPS 116 


Client sets to zero, optionally used by 
relay-agents when booting via a relay- 
agent. 




XID118 


Transaction ID, a random number 
chosen by the client, used by the client 


yg 

f% i 




anc server to associaxe messages ana 
responses oetween a client ana a 






server. 


yj 


SECS \4\J 


riiiea in uy client, seconas eiapsea 
since client started trying to boot. 




FLAGS 1 22 


Mags including a dkualjuaoi dii. 




CIADDR 124 


Client IP address; filled in by client in 
unurrvtuuco i it venTyiny previouoiy 
allocated configuration parameters. 




YIADDR 126 


'Your'(client) IP address. 




SIADDR 128 


IP 54 address of next server to use in 
bootstrap; returned in DHCPOFFER, 
DHCPACK and DHCPNAK by server. 




GIADDR 130 


Gateway relay agent IP 54 address, 
used in booting via a relay-agent. 




CHADDR 


Client hardware address (e.g., MAC 




132 


layer 44 address). 




SNAME 134 


Optional server host name, null 
terminated string. 




FILE 136 


Boot file name, terminated by a null 
string. 




OPTIONS 
138 


Optional parameters. 



5 Table 4. 



The DHCP 66 message structure shown in FIG. 6 is used to discover IP 54 and other 



network host interfaces in data-over-cable system 10. A network host client (e.g., the CM 16) 
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uses the DHCP 66 to acquire or verify an IP 54 address and network parameters whenever the 
network parameters may have changed. Table 5 illustrates a typical use of the DHCP 66 
protocol to discover a network host interface from a network host client. 



1 . A network host client broadcasts a DHCP 66 discover message on its local physical subnet. 
The DHCP 66 discover message may include options that suggest values for a network host 
interface address. BOOTP relay agents may pass the message on to DHCP 66 servers not 
on the same physical subnet. 

2. DHCP servers may respond with a DHCPOFFER message that includes an available 
network address in the ^teddr' field (and other configuration parameters in DHCP 66 options) 
from a network host interface. DHCP 66 servers unicasts the DHCPOFFER message to the 
network host client (using the DHCP/BOOTP relay agent if necessary) if possible, or may 
broadcast the message to a broadcast address (preferably 255.255.255.255) on the client's 
subnet. 

3. The network host client receives one or more DHCPOFFER messages from one or more 
O DHCP 66 servers. The network host client may choose to wait for multiple responses. 

: T: 4. The network host client chooses one DHCP 66 server with an associated network host 

12 interface from which to request configuration parameters, based on the configuration 

[ = parameters offered in the DHCPOFFER messages. 

y Table 5. 

,C 5 

Nf Discovering network host interfaces in the data-over-cable system 

^ The DHCP 66 discovery process illustrated in Table 5 will not work in data-over-cable 

system 10 with r without telephony return. In an exemplary preferred embodiment of the present 
invention with telephony return, the CM 16 discovers network host interfaces via TRAC 24 and 
10 the PSTN 22 on an upstream telephony connection. In another exemplary preferred embodiment 
of the present invention without telephony return, the CM 16 discovers network host interfaces 
via the CMTS 12 on an upstream cable connection. 

The DHCP 66 addressing process shown in Table 5 was not originally intended to 
discover network host interfaces in data-over-cable system 10. The CMTS 12 has DHCP 66 
15 servers associated with network host interfaces (e.g., IP 54 interfaces). However, in one 
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preferred embodiment of the present invention with telephony return, the CM 16 only has as 
downstream connection from the CMTS 12. The CM 16 has an upstream connection to TRAC 
24, which has a DHCP 66 layer. However, TRAC 24 does not have the DHCP 66 servers, or 
direct access to network host interfaces (e.g., IP 54 interfaces) associated with the CMTS 12. 
5 FIGS. 7 A and 7B are a flow diagram illustrating a Method 140 for discovering network 

host interfaces in data-over-cable system 10. In one preferred embodiment of the present 
inventions with telephony return, when the CM 16 has established an DP 54 link to TRAC 24, via 
PPP 50, it begins communications with the CMTS 12 via DHCP 66 to complete a virtual IP 54 
connection with the data network 28. However, to discover what IP 54 host interfaces might be 
10 available on the CMTS 12, the CM 16 has to communicate with the CMTS 12 via the PSTN 22 

yj- and TRAC 24 since the CM 16 only has a "downstream" cable channel from the CMTS 12 in a 

y data-over-cable system with telephony return. 

Si At Step 142 in FIG. 7A, after receiving a TSI message 76 from the CMTS 12 on a 

^ downstream connection, the CM 16 generates a DHCP discover ("DHCPDISCOVER") message 

rr 15 and sends it upstream via the PSTN 22 to TRAC 22 to discover what IP 54 interfaces are 
m associated with the CMTS 12. The fields of the DHCP 66 discover message are set as illustrated 
in Table 6. However, other field settings may also be used. 



DHCP 66 
Parameter 


Description 


OP 110 


Set to BOOTREQUEST. 


HTYPE 112 


Set to network type (e.g., one for 10 Mbps 
Ethernet). 


HLEN 114 


Set to network length (e.g., six for 10 Mbps 
Ethernet) 


HOPS 116 


Set to zero. 


FLAGS 122 


Set BROADCAST bit to zero. 


CIADDR 124 


if the CM 16 has previously been assigned an 
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IP 54 address, the IP 54 address is placed in 
this field. If the CM 16 has previously been 
assigned an IP 54 address by the DHCP 66, 
and also has been assigned an address via 
IPCP, the CM 16 places the DHCP 66 IP 54 
address in this field. 


GIADDR 130 


CM 16 places the Downstream Channel IP 54 
address 80 of the CMTS 12 obtained in TSI 
message 76 on a cable downstream channel 
in this field. 


CHADDR 1 32 


CM 16 places its 48-bit MAC 44 LAN address 
in this field. 



Table 6. 



The DHCPDISCOVER message is used to "discover" the existence of one or more IP 54 



5 host interfaces associated with the CMTS 12. The DHCP 66 giaddr-field 130 (FIG. 6) includes a 



downstream channel IP address 80 of the CMTS 12 obtained in TSI message 76 (e.g., the first 



message field from Step 96 of Method 92). Using the downstream channel IP address 80 of the 



CMTS 12 obtained in TSI message 76 allows the DHCPDISCOVER message to be forwarded 



by TRAC 24 to the DHCP 66 servers (i.e., protocol servers) associated with network host 



10 interfaces associated with the CMTS 12. If the DHCP 66 giaddr-field 130 (FIG. 6) in a DHCP 



message from a DHCP 66 client is non-zero, a DHCP 66 server sends any return messages to a 



DHCP 66 server port on a DHCP 66 relaying agent (e.g., the CMTS 12) whose address appears 



in the DHCP 66 giaddr-field 130. 



In a typical DHCP 66 discovery process, the DHCP 66 giaddr-field 130 is set to zero. 



15 However, in one preferred embodiment of the present invention, the DHCP 66 giaddr-field 130 



contains the IP address 80 of the CMTS 12. If the DHCP 66 giaddr-field 130 is zero, the DHCP 



66 client is on the same subnet as the DHCP 66 server, and the DHCP 66 server sends any return 



messages to either the DHCP 66 client's network address, if that address was supplied in the 
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DHCP 66 ciaddr-field 124 (FIG. 6), or to a client's hardware address (e.g., MAC address 44) 
specified in the DHCP 66 chaddr-field 132 (FIG. 6) or to a local subnet broadcast address (e.g., 
255.255.255.255). 

At Step 144, a DHCP 66 layer on TRAC 24 broadcasts the DHCPDISCOVER message 
5 on its local network leaving the DHCP 66 giaddr- field 130 intact since it already contains a non- 
zero value. TRAC's 24 local network includes connections to one or more DHCP 66 proxies 
(i.e., network host interface proxies). The DHCP 66 proxies accept the DHCP 66 messages 
originally from the CM 16 destined for DHCP 66 servers associated with network host interfaces 
associated with the CMTS 12. The TRAC 24 has no direct access to DHCP 66 servers 
y3 10 associated with network host interfaces associated with the CMTS 12. The DHCP 66 proxies are 
M= not used in a typical the DHCP 66 discovery process known on the art. 

^ One or more DHCP 66 proxies on TRAC's 24 local network recognizes the 

"~ DHCPDISCOVER message and forwards it to one or more DHCP 66 servers associated with 

k i network host interfaces (e.g., IP 54 interfaces) associated with the CMTS 12 at Step 146. Since 
|I 15 the DHCP 66 giaddr-field 130 (FIG. 6) in the DHCPDISCOVER message sent by the CM 16 is 
£0 already non-zero (i.e., contains the downstream IP address of the CMTS 12), the DHCP 66 

proxies also leave the DHCP 66 giaddr-field 130 intact. 

One or more DHCP 66 servers for network host interfaces (e.g., IP 54 interfaces) 
available on the CMTS 12 receive the DHCPDISCOVER message and generate a DHCP 66 
20 offer message ("DHCPOFFER") at Step 148. The DHCP 66 offer message is an offer of 

configuration parameters sent from network host interfaces to the DHCP 66 servers and back to a 
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network host client (e.g., the CM 16) in response to a DHCPDISCOVER message. The DHCP 
66 offer message is sent with the message fields set as illustrated in Table 7. However, other 
field settings can also be used. The DHCP 66 yiaddr-field 126 (e.g., second message field from 
Step 102 of Method 92) contains an IP 54 address for a network host interface available on the 
5 CMTS 12 and used for receiving data packets from data network 28. 



DHCP 66 Parameter 


Description 


FLAGS 122 


BROADCAST bit set to zero. 


YIADDR 126 


IP 54 address from a network 
host interface to allow the CM 16 
to receive data from data 
network 28 via a network host 
interface available on the CMTS 
12. 


SIADDR 128 


An IP 54 address for a TFTP 64 
server to download configuration 
information for an interface host. 


CHADDR 132 


MAC 44 address of the CM 16. 


SNAME 134 


Optional DHCP 66 server 
identifier with an interface host. 


FILE 136 


A TFTP 64 configuration file 
name for the CM 16. 



Table 7. 



DHCP 66 servers send the DHCPOFFER message to the address specified in the DHCP 



fj] 66 giaddr-field 130 (i.e., the CMTS 12) from the DHCPDISCOVER message if associated 
%n io network host interfaces (e.g., IP 54 interfaces) can offer the requested service (e.g., IP 54 



service) to the CM 16. The DHCPDISOVER message DHCP 66 giaddr-field 130 contains a 



downstream channel IP address 80 of the CMTS 12 that was received by the CM 16 in TSI 



message 76. This allows the CMTS 12 to receive the DHCPOFFER messages from the DHCP 



66 servers and send them to the CM 16 via a downstream channel on cable network 14. 



15 At Step 150 in FIG. 7B, the CMTS 12 receives one or more DHCPOFFER messages 



from one or more DHCP 66 servers associated with the network host interfaces (e.g., IP 54 
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interfaces). THE CMTS 12 examines the DHCP 66 yiaddr-field 126 and DHCP 66 chaddr-field 
132 in the DHCPOFFER messages and sends the DHCPOFFER messages to the CM 16 via 
cable network 14. The DHCP 66 yiaddr-field 126 contains an IP 54 address for a network host 
IP 54 interface available on the CMTS 12 and used for receiving IP 54 data packets from data 
5 network 28. The DHCP 66 chaddr-field 132 contains the MAC 44 layer address for the CM 16 
on a downstream cable channel from the CMTS 12 via cable network 14. The CMTS 12 
"knows" the location of the CM 16 since it sent the CM 16 a MAC 44 layer address in one or 
more initialization messages (e.g., TSI message 76). 

If a BROADCAST bit in flags-field 124 is set to one, the CMTS 12 sends the 
10 DHCPOFFER messages to a broadcast IP 54 address (e.g., 255.255.255.255) instead of the 
i address specified in the DHCP 66 yiaddr-field 126. The DHCP 66 chaddr-field 132 is still used 
yj to determine that MAC 44 layer address. If the BROADCAST bit in the DHCP 66 flags-field 
S J 122 is set, the CMTS 12 does not update internal address or routing tables based upon the DHCP 
tf; 66 yiaddr-field 126 and the DHCP 66 chaddr-field 132 pair when a broadcast message is sent. 
\z 15 At Step 152, the CM 16 receives one or more DHCPOFFER messages from the CMTS 

J5 12 via cable network 14 on a downstream connection. At Step 154, the CM 16 selects an offer 

for IP 54 service from one of the network host interfaces (e.g., an IP interfaces 54) associated 
with the CMTS 12 that responded to the DHCPDISOVER message sent at Step 142 in FIG. 7A 
and establishes a virtual IP 54 connection. The selected DHCPOFFER message contains a 
20 network host interface address (e.g., IP 54 address) in the DHCP 66 yiaddr-field 126 (FIG. 6). A 
CM 16 acknowledges the selected network host interface with a DHCP 66 message sequence 
explained below. 
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After selecting and acknowledging a network host interface, the CM 16 has discovered an 
IP 54 interface address available on the CMTS 12 for completing a virtual IP 54 connection with 
the data network 28. Acknowledging a network host interface is explained below. The virtual IP 
54 connection allows IP 54 data from the data network 28 to be sent to the CMTS 12 which 
5 forwards the IP 54 packets to the CM 16 on a downstream channel via the cable network 14. 
The CM 16 sends response IP 54 packets back to data network 28 via the PSTN 22 and the 
TRAC 24 if telephony return is used. The CM sends response IP packets back to the data 
network 28 via the CMTS 12 if a two-way cable network is used. 

FIG. 8 is a block diagram illustrating an exemplary data-over-cable system 156 for the 
% 10 Method illustrated in FIGS. 7 A and 7B. Data-over-cable system 156 includes DHCP 66 proxies 
II ("P") 158, DHCP 66 servers ("S") 160 and associated Network Host Interfaces ("NHI") 162 
y available on the CMTS 12. Multiple DHCP 66 proxies 158, DHCP 66 servers 160 and network 
^ host interfaces 162 are illustrated as single boxes in FIG. 8. FIG. 8 also illustrates the DHCP 66 
Li proxies 158 separate from TRAC 24. In one embodiment of the present invention, the TRAC 24 

Jj 15 includes integral DHCP 66 proxy functionality and no separate DHCP 66 proxies 158 are used. 
m hi such an embodiment, TRAC 24 forwards the DHCP 66 messages using the DHCP 66 giaddr- 

field 130 to the DHCP 66 servers 160 associated with the CMTS 12. 

FIG. 9 is a block diagram illustrating a message flow 162 of Method 140 (FIGS. 7 A and 
7B). Message flow 162 includes the DHCP proxies 158 and the DHCP servers 160 illustrated in 
20 FIG. 8 Steps 142, 144, 146, 148, 150 and 154 of Method 140 (FIGS. 7A and 7B) are illustrated 
in FIG. 9. In one embodiment of the present invention, the DHCP proxies 158 are not separate 
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entities, but are included in TRAC 24. In such an embodiment, the DHCP proxy services are 

provided directly by TRAC 24. 

Resolving addresses for network host interfaces 

Since the CM 16 receives multiple the DHCPOFFER messages (Step 152 FIG. 7B) the 
5 CM 16 resolves and acknowledges one offer from a selected network host interface. FIGS. 10A 
and 1 OB are a flow diagram illustrating a Method 166 for resolving and acknowledging host 
addresses in a data-over-cable system. Method 166 includes a first network device that is 
connected to a first network with a downstream connection of a first connection type, and 
connected to a second network with an upstream connection of a second connection type. The 
*i 10 first and second networks are connected to a third network with a third connection type. In one 
II embodiment of the present invention, the first network device is the CM 16, the first network is 

hi cable network 14, the second network is the PSTN 22 and the third network is data network 28 

(e.g., the Internet). The downstream connection is a cable television connection, the upstream 
L] connection is a telephony connection, and the third connection is an IP connection. However, 

rf 15 the upstream connection and the data stream connection can both be cable television connections 
m for use in a data-over-cable system without telephony return. 

Turning to FIG. 10A, one or more first messages are received on the first network device 
from the first network on the downstream connection at Step 168. The one or more first 
messages are offers from one or more network host interfaces available on the first network to 
20 provide the first network device a connection to the third network. The first network device 
selects one of the network host interfaces using message fields in one of the one or more first 
messages at Step 170. The first network device creates a second message with a second message 
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type to accept the offered services from a selected network host interface at Step 172. The 
second message includes a connection address for the first network in a first message field and 
an identifier to identify the selected network host interface in a second message field. 

The first network device sends the second message over the upstream connection to the 
5 second network at Step 174. The second network uses the first message field in the second 
message to forward the second message to the one or more network host interfaces available on 
first network at Step 176. 

A network host interface available on the first network identified in second message field 
in the second message from the first network device recognizes an identifier for the network host 
*S 10 interface at Step 178 in FIG. 10B. The selected network host interface sends a third message 
|I with a third message type to the first network at Step 180. The third message is an 
yj acknowledgment for the first network device that the selected network host interface received the 
Si second message from the first network device. The first network stores a connection address for 
if" the selected network interface in one or more tables on the first network at Step 182. The first 
I* 15 network will forward data from the third network to the first network device when it is received 
m on the selected network host interface using the connection address in the one or more routing 

tables. The first network forwards the third message to the first network device on the 
downstream connection at Step 184. The first network device receives the third message at Step 
186. The first network and the first network device have the necessary addresses for a virtual 
20 connection that allows data to be sent from the third network to a network host interface on the 
first network, and from the first network over the downstream connection to the first network 
device. Method 166 accomplishes resolving network interface hosts addresses from a cable 
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modem in a data-over-cable with or without telephony return. 

Method 166 of the present invention is used in data-over-cable system 10 with telephony 
return. However, the present invention is not limited to data-over-cable system 10 with 
telephony return and can be used in data-over-cable system 10 without telephony return by using 
an upstream cable channel instead of an upstream telephony channel. 

FIGS. 1 1 A and 1 IB are a flow diagram illustrating a Method 188 for resolving 
discovered host addresses in data-over-cable system 10 with telephony return. At Step 190 in 
FIG. 1 1 A, the CM 16 receives one or more DHCPOFFER messages from one or more of the 
DHCP 66 servers 160 associated with one or more network host interfaces 162 associated with 
the CMTS 12 (e.g., at Step 168 in Method 166). The one or more DHCPOFFER messages 
include the DHCP 66 fields set as illustrated in Table 7 above. However, other field settings 
could also be used. At Step 192, the CM 16 selects one of the DHCPOFFER messages (see also, 
Step 170 in Method 166). At Step 194, the CM 16 creates a DHCP 66 request message 
("DHCPREQUEST") message to request the services offered by a network host interface 168 
selected at Step 192. The fields of the DHCP request message are set as illustrated in Table 8. 
However, other field settings may also be used. 



DHCP 66 
Parameter 


Description 


OP 110 


Set to BOOTREQUEST. 


HTYPE 112 


Set to network type (e.g., one for 10Mbps 
Ethernet). 


HLEN 114 


Set to network length (e.g., six for 10Mbps 
Ethernet) 


HOPS 116 


Set to zero. 


FLAGS 122 


Set BROADCAST bit to zero. 


CIADDR 124 


If the CM 1 6 has previously been assigned an 
IP address, the IP address is placed in this 
field. If the CM 16 has previously been 
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assigned an IP address by the DHCP 66, and 
also has been assigned an address via IPCP, 
the CM 16 places the DHCP 66 IP 54 address 
in this field. 


YIADDR 126 


IP 54 address sent from the selected network 
interface host in DHCPOFFER message 


GIADDR 130 


CM 16 places the Downstream Channel IP 54 
address 80 the CMTS 12 obtained in TSi 
message 76 on a cable downstream channel 
in this field. 


CHADDR 1 32 


CM 16 places its 48-bit MAC 44 LAN address 
in this field. 


SNAME 134 


DHCP 66 server identifier for the selected 
network interface host 



Table 8. 



The DHCPREQUEST message is used to "request" services from the selected IP 54 host 



interface 162 associated with the CMTS 12 using a DHCP 66 server 160 associated with the 



selected network host interface 162. The DHCP 66 giaddr-field 130 (FIG. 6) includes the 



downstream channel IP address 80 for the CMTS 12 obtained in TSI message 76 (e.g., the first 



message-field from Step 172 of Method 166). Putting the downstream channel IP address 80 



obtained in TSI message 76 in a DHCPREQUEST message allows the DHCPREQUEST 



message to be forwarded by the TRAC 24 to the DHCP 66 servers 160 associated with network 



host interfaces 162 associated with the CMTS 12. The DHCP 66 giaddr-field 126 contains an 



identifier (e.g., second message field, Step 172 in Method 166) and the DHCP 66 sname-field 



134 contains a DHCP 66 server identifier 160 associated with the selected network host 



interface. 



If the DHCP 66 giaddr-field 130 in a DHCP 66 message from a DHCP 66 client is non- 



zero, a DHCP 66 server 160 sends any return messages to a DHCP 66 server port on a DHCP 66 



15 relaying agent (e.g., the CMTS 12) whose address appears in DHCP 66 giaddr-field 130. If 
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DHCP 66 giaddr-field 130 is zero, the DHCP 66 client is on the same subnet as the DHCP 66 
server, and the DHCP 66 server sends any return messages to either the DHCP 66 client's 
network address, if that address was supplied in the DHCP 66 ciaddr-field 124, or to the client's 
hardware address specified in the DHCP 66 chaddr-field 132 or to the local subnet broadcast 
5 address. 

Returning to FIG. 1 1A at Step 196, the CM 16 sends the DHCPREQUEST message on 
the upstream connection to TRAC 24 via the PSTN 22. At Step 198, a DHCP 66 layer on TRAC 
24 broadcasts the DHCPREQUEST message on its local network leaving the DHCP 66 giaddr- 
field 130 intact since it already contains a non-zero value. The TRACs 24 local network 
-J 10 includes connections to one or more DHCP 66 proxies 158. The DHCP 66 proxies 158 accept 
H DHCP 66 messages originally from the CM 16 destined for the DHCP 66 servers 160 associated 
yj with network host interfaces 168 associated with the CMTS 12. In another embodiment of the 
" present invention, TRAC 24 provides the DHCP 66 proxy functionality, and no separate DHCP 
H i 66 proxies are used. 

jM* 15 The one or more DHCP 66 proxies 158 on TRACs 24 local network message forwards 

Hi the DHCPOFFER to one or more of the DHCP 66 servers 160 associated with network host 

interfaces 162 (e.g., IP 54 interfaces) available on the CMTS 12 at Step 200 in FIG. 1 IB. Since 
DHCP 66 giaddr-field 130 in the DHCPDISCOVER message sent by the CM 16 is already non- 
zero (i.e., contains the downstream IP address of the CMTS 12), the DHCP 66 proxies leave 158 
20 the DHCP 66 giaddr-field 130 intact. 

One or more of the DHCP 66 servers 160 for the selected network host interfaces 162 
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(e.g., IP 54 interface) associated with the CMTS 12 receives the DHCPOFFER message at Step 
202. A selected DHCP 66 server 160 recognizes a DHCP 66 server identifier in the DHCP 66 
sname-field 134 or the IP 54 address that was sent in the DHCPOFFER message in the DHCP 66 
yiaddr-field 126 from the DHCPREQUST message as being for the selected DHCP 66 server 
5 160. 

The selected DHCP 66 server 160 associated with network host interface 162 selected 
by the CM 16 in the DHCPREQUEST message creates and sends a DHCP 66 acknowledgment 
message ("DHCPACK") to the CMTS 12 at Step 204. The DHCPACK message is sent with the 
message fields set as illustrated in Table 9. However, other field settings can also be used. The 
y 10 DHCP 66 yiaddr-field again contains the IP 54 address for the selected network host interface 
12 available on the CMTS 12 for receiving data packets from data network 28, 



DHCP 66 Parameter 


Description 


FLAGS 122 


Set a BROADCAST bit to zero. 


YIADDR 126 


IP 54 address for the selected 
network host interface to allow 
the CM 16 to receive data from 
data network 28. 


SIADDR 128 


An IP 54 address for a TFTP 64 
server to download configuration 
information for an interface host. 


CHADDR 1 32 


MAC 44 address of the CM 16. 


SNAME 134 


DHCP 66 server identifier 
associated with the selected 
network host interface. 


FILE 136 


A configuration file name for an 
network interface host. 



Table 9. 



The selected DHCP 66 server 160 sends the DHCACK message to the address specified in the 
DHCP 66 giaddr-field 130 from the DHCPREQUEST message to the CM 16 to verify the 
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selected network host interface (e.g., IP 54 interface) will offer the requested service (e.g., IP 54 
service). 

At Step 206, the CMTS 12 receives the DHCPACK message from the selected DHCP 66 
server 160 associated with the selected network host interface 162 IP 54 address(e.g. ? IP 54 
5 interface). The CMTS 12 examines the DHCP 66 yiaddr-field 126 and the DHCP 66 chaddr- 
field 132 in the DHCPACK message. The DHCP 66 yiaddr-field 126 contains an IP 54 address 
for a network host IP 54 interface available on the CMTS 12 and used for receiving IP 54 data 
packets from data network 28 for the CM 16. The DHCP 66 chaddr-field 132 contains the MAC 
44 layer address for the CM 16 on a downstream cable channel from the CMTS 12 via cable 
;i 10 network 14. 

ll CMTS 12 updates an Address Resolution Protocol ("ARP") table and other routing tables 

Ly on the CMTS 12 to reflect the addresses in the DHCP 66 yiaddr-field 126 and the DHCP 66 
SS chaddr-field 132 at Step 208. As is known in the art, ARP allows a gateway such as the CMTS 
!f: 12 to forward any datagrams from a data network such as data network 28 it receives for hosts 
; j 15 such as the CM 16. For more information on ARP see, RFC-826, incorporated herein by 
m reference. 

CMTS 12 stores a pair of network address values in the ARP table, the IP 54 address of 
the selected network host interface from the DHCP 66 yiaddr-field 126 and a Network Point of 
Attachment ("NPA") address. In one preferred embodiment of the present invention, The NPA 
20 address is a MAC 44 layer address for the CM 16 via a downstream cable channel. The IP/NPA 
address pair are stored in local routing tables with the IP/NPA addresses of hosts (e.g., the CMs 
16) that are attached to cable network 14. 
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At Step 210, the CMTS 12 sends the DHCPACK message to the CM 16 via the cable 
network 14. At Step 212, the CM 16 receives the DHCPACK message, and along with the 
CMTS 12 has addresses for a "virtual connection" between the data network 28 and the CM 16. 
When data packets arrive on the IP 54 address for the selected CM 16 they are sent to the CMTS 
5 12 and the CMTS 12 forwards them using a NPA (i.e., a MAC 44 address) from the routing 
tables on a downstream channel via the cable network 14 to the CM 16. 

If a BROADCAST bit in the DHCP 66 flags-field 124 is set to one in the DHCPACK, the 
CMTS 12 sends the DHCPACK messages to a broadcast IP 54 address (e.g., 255.255.255.255). 
The DHCP 66 chaddr-field 132 is still used to determine a MAC 44 layer address. If the 
3 10 BROADCAST bit in the DHCP 66 flags field 122 is set, the CMTS 12 does not update the ARP 
Li table or other routing tables based upon the DHCP 66 yiaddr-field 126 and the DHCP 66 chaddr- 
y field 132 pair when a broadcast message is sent. 

SI FIG. 12 is a block diagram illustrating the message flow 214 of the Method 188 

illustrated in FIGS. 11A and 11B. Message flow 214 includes the DHCP proxies 158 and the 

[J 15 DHCP servers 160 illustrated in FIG. 8. Method Steps 194, 196, 198, 204, 208, 210and 212 of 
Method 188 (FIGS. 1 1 A and 1 IB) are illustrated in FIG. 12. In one embodiment of the present 
invention, the DHCP proxies 158 are not separate entities, but are included in TRAC 24. In such 
an embodiment, the DHCP proxy services are provided directly by TRAC 24. 

After Method 188, the CMTS 12 has a valid IP/MAC address pair in one or more address 
20 routing tables including an ARP table to forward IP 54 data packets from data network 28 to the 
CM 16, thereby creating a virtual IP 54 data path to/from the CM 16 as was illustrated in Method 
92 (FIG. 5) and Table 3. The CM 16 has necessary parameters to proceed to the next phase of 
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initialization, a downloading of a configuration file via TFTP 64. Once the CM 16 has received 
the configuration file and has been initialized, it registers with the CMTS 12 with w registration 
message and is ready to receive data from data network 14. 

In the event that the CM 16 is not compatible with the configuration of the network host 
5 interface 162 received in the DHCPACK message, the CM 16 may generate a DHCP 66 decline 
message ("DHCPDECLINE") and transmit it to TRAC 24 via the PSTN 22. A DHCP 66 layer 
in TRAC 24 forwards the DHCPDECLINE message to the DHCP servers 160 and the CMTS 12. 
Upon seeing a DHCPDECLINE message, the CMTS 12 flushes its ARP tables and routing tables 
to remove the now invalid IP/MAC pairing. The CM 16 may also send the DHCPDECLINE 
% 10 message to the CMTS 12 on an upstream cable channel. The CMTS 12 will then forward the 
12 DHCPDECLINE message to the appropriate DHCP 66 server 160. If an IP 54 address for a 
hj network host interface is returned in a DHCPACK that is different from the IP 54 address sent by 

Si the CM 16 in the DCHCPREQUEST message, the CM 16 uses the IP 54 address it receives in 
if; the DHCPACK message as the IP 54 address of the selected network host interface for receiving 
12 15 data from data network 28 . 

One preferred embodiment of the present invention is described with respect to, but is not 
limited to a data-over-cable-system with telephony return. Method 188 can also be used with a 
cable modem that has a two-way connection (i.e., upstream and downstream) to the cable 
network 14 and the CMTS 12. In a data-over-cable-system without telephony return, the CM 16 
20 would broadcast the DHCPREQUEST message to one or more DHCP 66 servers 160 associated 
with one or more network host interfaces 162 associated with the CMTS 12 using an upstream 
cable connection on the data network 14 including the IP 54 address of the CMTS 12 in the 
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DHCP 66 giaddr-field 130. Method 188 accomplishes resolving addresses for network interface 
hosts from a cable modem in a data-over-cable with or without telephony return, and without 
extensions to the existing DHCP protocol. 
CPE initialization in a data-over-cable system 
5 The CPE 18 also uses the DHCP 66 to generate requests to obtain IP 54 addresses to 

allow CPE 18 to also receive data from data network 28 via the CM 16. In a preferred 
embodiment of the present invention, the CM 16 functions as a standard BOOTP relay 
agent/DHCP Proxy 158 to facilitate CPE's 18 access to the DHCP 66 server 160. FIGS. 13A 
and 13B are a flow diagram illustrating a Method 216 for obtaining addresses for customer 
if 10 premise equipment such as the CPE 18. The CM 16 and the CMTS 12 use information from 
Li Method 214 to construct IP 54 routing and ARP table entries for network host interfaces 162 
y providing data to the CMCI 20 and to CPE 18. 

Method 216 in FIGS. 13 A and 13B includes a data-over-cable system with telephony 
hj return. A first network device with a second network device is used for connecting the first 

15 network device to a first network with a downstream connection of a first connection type, and 
|B for connecting to a second network with an upstream connection of a second connection typo. 

The first and second networks are connected to a third network with a third connection type. 

In one embodiment of the present invention, data-over-cable system with telephony 
return is data-over-cable system 10 with the first network device is the CPE 18 and the second 
20 network device is the CM 16. The first network is the cable television network 14, the 

downstream connection is a cable television connection, the second network is the PSTN 22, the 
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upstream connection is a telephony connection, the third network is data network 28 (e.g., the 
Internet or an intranet) and the third type of connection is an IP 54 connection. However, the 
present invention is not limited to the network components described and other network 
components may also be used. A data-over-cable system without telephony return can also be 
5 used (e.g., a system with a two-way cable channel. Method 216 allows CPE 18 to determine an 
IP 54 network host interface address available on the CMTS 12 to receive IP 54 data packets 
from the data network 54, thereby establishing a virtual IP 54 connection with data network 28 
via the CM 16. 

Returning to FIG. 13A at Step 218, a first message of a first type (e.g., a DHCP 66 
10 discover message) with a first message field for a first connection is created on the first network 
12 device. The first message is used to discover a network host interface address on the first 
yj network to allow a virtual connection to the third network. 

Nf At Step 220, the first network device sends the first message to the second network 

device. The second network device checks the first message field at Step 222. If the first 
lz 15 message field is zero, the second network device puts its own network connection address into 
,5 the first message field at Step 224. The second network device connection address allows the 
messages from network host interfaces on the first network to return messages to the second 
network device attached to the first network device. If the first message field is non-zero, the 
second network device does not alter the first message field since there could be a relay agent 
20 attached to the first network device that may set the first connection address field. 

At Step 226, the second network device forwards the first message to a connection 
address over the upstream connection to the second network. In one embodiment of the present 
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invention, the connection address is an IP broadcast address (e.g., 255.255.255.255). However, 
other connection addresses can also be used. 

The second network uses the first connection address in the first message field in the first 
message to forward the first message to one or more network host interfaces (e.g., IP 54 network 
5 host interfaces 162) available on first network at Step 228. One or more network host interfaces 
available on the first network that can provide the services requested in first message send a 
second message with a second message type with a second connection address in a second 
message field to the first network at Step 230 in FIG. 13B. The second connection address 
allows the first network device to receive data packets from the third network via a network host 
"7: 10 interface on the first network. The first network forwards the one or more second messages on 
12 the downstream connection to the second network device at Step 232. The second network 
hj device forwards the one or more second messages to the first network device at Step 234. The 
N! first network device selects one of the one or more network host interfaces on the first network 
H; using the one or more second messages at Step 236. This allows a virtual connection to be 
! ^ 15 established between the third network and the first network device via the selected network host 
S interface on the first network and the second network device. 

FIGS. 14A and 14B are a flow diagram illustrating a Method 240 for resolving addresses 
for the network host interface selected by a first network device to create a virtual connection to 
the third network. Turning to FIG. 14A, at Step 240 one or more second messages are received 
20 with a second message type on the first network device from the second network device from the 
first network on a downstream connection at Step 242. The one or more second messages are 
offers from one or more protocol servers associated with one or more network host interfaces 
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available on the first network to provide the first network device a connection to the third 
network. The first network device selects one of the network host interfaces using one of the one 
or more second messages at Step 244. The first network device creates a third message with a 
third message type to accept the offered services from the selected network host interface at Step 
5 246. The third message includes a connection address for the first network in a first message 
field and an identifier to identify the selected network host interface in a second message field. 
At Step 248 , first network device equipment sends the third message to the second network 
device. 

The second network device sends the third message over the upstream connection to the 
*i 10 second network at Step 250. The second network uses the first message field in the third 
11 message to forward the third message to the one or more network host interfaces available on 
yj first network at Step 252. 

Si A network host interface available on the first network identified in second message field 

jr: in the third message from the first network device recognizes an identifier for the selected 
\z 15 network host interface at Step 254 in FIG. 14B. The selected network host interface sends a 
'ffi fourth message with a fourth message type to the first network at Step 256. The fourth message 

is an acknowledgment for the first network device that the selected network host interface 
received the third message. The fourth message includes a second connection address in a third 
message field. The second connection address is a connection address for the selected network 
20 host interface. The first network stores the connection address for the selected network interface 
from the third message in one or more routing tables (e.g., an ARP table) on the first network at 
Step 258. The first network will forward data from the third network to the first network device 

-52- 

McDonnell boehnen 
hulbert & berg ho ff 
300 south wacker drive 
chicago, illinois 60606 
telephone (312) 913-0001 



via the second network device when it is received on the selected network host interface using 
the connection address from the third message field. The first network forwards the fourth 
message to the second network device on the downstream connection at Step 260. The second 
network device receives the fourth message and stores the connection address from the third 
5 message field for the selected network interface in one or more routing tables on the second 
network device at Step 262. The connection address for the selected network interface allows 
the second network device to forward data from the third network sent by the selected network 
interface to the customer premise equipment. At Step 264, the second network device forward 
the fourth message to the first network device. At Step 266, the first network device establishes 
if 10 a virtual connection between the third network and the first network device. 
\ T After Step 266, the first network, the second network device and the first network device 

hj have the necessary connection addresses for a virtual connection that allows data to be sent from 
SI. the third network to a network host interface on the first network, and from the first network over 
^ the downstream connection to the second network and then to the first network device. In one 
yt 15 embodiment of the present invention, Method 240 accomplishes resolving network interface 
^ hosts addresses from customer premise equipment with a cable modem in a data-over-cable with 

telephony return without extensions to the existing DHCP protocol. 

Methods 216 and 240 of the present invention are used in data-over-cable system 10 with 
telephony return with the CM 16 and CPE 18. However, the present invention is not limited to 
20 data-over-cable system 10 with telephony return and can be used in data-over-cable system 10 
without telephony return by using an upstream cable channel instead of an upstream telephony 
channel. 
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FIGS. 15A and 15B are a flow diagram illustrating a Method 268 for addressing 
network host interfaces 162 from CPE 18. At Step 270 in FIG. 15 A, the CPE 18 generates a 
DHCPDISCOVER message broadcasts the DHCPDISCOVER message on its local network with 
the fields set as illustrated in Table 6 above with addresses for CPE 18 instead of the CM 16. 
5 However, more or fewer field could also be set in the DHCPDISCOVER message. The CM 16 
receives the DHCPDISCOVER as a standard BOOTP relay agent at Step 272. The 
DHCPDISCOVER message has a MAC 44 layer address for the CPE 18 in the DHCP 66 
chaddr-field 132, which the CM 16 stores in one or more routing tables. As a BOOTP relay 
agent, the CM 16 checks the DHCP 66 giaddr-field 130 (FIG. 6) at Step 274. If the DHCP 66 

l t 10 giaddr-field 130 is set to zero, the CM 16 put its own IP 54 address into the DHCP 66 giaddr- 

11 field 130 at Step 276, including the CM 16 is a relay agent. 

yj If the DHCP 66 giaddr-field 130 is non-zero, the CM 16 does not alter the DHCP 66 

%i giaddr-field 130 since there could be another BOOTP relay agent attached to CPE 18 which may 
have already set the DHCP 66 giaddr-field 130. Any BOOTP relay agent attached to CPE 18 
15 would have also have acquired its IP 54 address using a DHCP 66 discovery process similar to 
S the one described above (e.g., FIG 12). 

Returning to FIG. 15A, at Step 278, the CM 16 broadcasts the DHCPDISCOVER 
message to a broadcast address via the PSTN 22 to the TRAC 24. In one embodiment of the 
present invention, the broadcast address is an IP 54 broadcast address (e.g., 255.255.255.255). 
20 At Step 280, one or more DHCP 66 proxies 158 associated with TRAC 24, recognize the 

DHCPDISOVER message, and forward it to one or more DHCP 66 servers 160 associated with 
one or more network host interfaces 162 associated with the CMTS 12. Since the DHCP 66 
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giaddr-field 130 is already non-zero, the DHCP proxies 160 leave the DHCP 66 giaddr-field 130 
intact. In another embodiment of the present invention, TRAC 24 includes DHCP 66 proxy 158 
functionality and no separate DHCP 66 proxies 158 are used. In yet another embodiment of the 
present invention, the CM 16 broadcasts the DHCPDISCOVER message to the CMTS 12 on an 
5 upstream cable channel. The CMTS 12 forwards the DHCPDISCOVER message to one or more 
DHCP servers 160. 

At Step 282 in FIG. 15B, the one or more DHCP servers 160 receive the 
DHCPDISCOVER message from one or more DHCP proxies 158 and generate one or more 
DHCPOFFER messages to offer connection services for one or more network host interfaces 162 
y 10 associated with the CMTS 12 with fields set as illustrated in Table 7. The one or more DHCP 
aJL 66 servers 160 send the one or more DHCPOFFER messages to the address specified in the 
y DHCP 66 giaddr-field 130 (e.g., the CM 16 or a BOOTP relay agent associated with CPE 18), 
SI which is an IP 54 address already contained in an ARP or other routing table in the CMTS 12. 
H; Since the CMTS 12 also functions as a relay agent for the one or more DHCP servers 160, the 
j y 15 one or more DHCPOFFER messages are received on the CMTS 12 at Step 284. 
|J The CMTS 12 examines the DHCP 66 yiaddr-field 126 and the DHCP 66 giaddr-field 

130 in the DHCPOFFER messages, and sends the DHCPOFFER messages down cable network 
14 to IP 54 address specified in the DHCP 66 giaddr-field 130. The MAC 44 address for the CM 
16 is obtained through a look-up of the hardware address associated with the DHCP 66 chaddr- 
20 field 130 (e.g., using ARP). If the BROADCAST bit in the DHCP 66 flags-field 122 is set to 
one, the CMTS 12 sends the DHCPOFFER message to a broadcast IP 54 address (e.g., 
255.255.255.255), instead of the address specified in the DHCP 66 yiaddr-field 126. The CMTS 
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12 does not update its ARP or other routing tables based upon the broadcast DHCP 66 yiaddr- 
field 126 DHCP 66 chaddr-field 132 address pair. 

Returning to FIG. 15B ? the CM 16 receives the one or more DHCPOFFER messages and 
forwards them to CPE 18 at Step 286. The CM 16 uses the MAC 44 address specified by the 
5 DHCP 66 chaddr-field 132 look-up in its routing tables (e.g., ARP table) to find the address of 
CPE 18 even if the BROADCAST bit in the DHCP 66 flags-field 122 is set. At Step 290, the 
CPE 18 receives the one or more DHCPOFFER messages from the CM 16. At Step 292, CPE 
the 18 selects one of the DHCPOFFER messages to allow a virtual connection to be established 
between the data network 28 and the CPE 18. Method 266 accomplishes addressing network 

§ ~ 5 10 interface hosts from CPE 18 in data-over-cable system 10 without extensions to the existing 

LI DHCP 66 protocol. 

hi FIGS. 16A and 16B are a flow diagram illustrating a Method 294 for resolving network 

SJ host interfaces from the CPE 18. At Step 296, the CPE 18 receives the one or more 
M: DHCPOFFER messages from the one or more DHCP 66 servers 160 associated with the one or 
; y 15 more network host interfaces associated with the CMTS 12. At Step 298, the CPE 18 chooses 
one offer of services from a selected network host interface 162. At Step 300, the CPE 1 8 
generates a DHCPREQUEST message with fields set as illustrated in Table 8 above with 
addresses for CPE 18 instead of the CM 16. However, more or fewer fields could also be set. At 
Step 302, CPE 18 sends the DHCPREQUEST message to the CM 16. At Step 304, the CM 16 
20 forwards the message to TRAC 24 via the PSTN 22 (or to the CMTS 12 via an upstream cable 
channel if a two-way cable system is being used). 
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At Step 306, a DHCP proxies 158 associated with the TRAC 24 broadcasts the 
DHCPREQUEST message on its local network leaving the DHCP 66 giaddr-field 130 intact 
since it already contains a non-zero value. The TRAC's 24 local network includes connections to 
one or more DHCP 66 proxies 158. The DHCP 66 proxies 158 accept the DHCP 66 messages 
5 originally from the CPE 1 8 destined for the DHCP 66 servers 160 associated with network host 
interfaces 162 associated with the CMTS 12. In another embodiment of the present invention, 
TRAC 24 provides the DHCP 66 proxy functionality, and no separate DHCP 66 proxies 158 are 
used. 

One or more DHCP 66 proxies 158 on TRAC's 24 local network recognize the 
% 10 DHCPOFFER message and forward it to one or more of the DHCP 66 servers 160 associated 
y[ with network host interfaces 162 (e.g., IP 54 interfaces) associated with the on the CMTS 12 at 
yj Step 308 in FIG. 16B. Since the DHCP 66 giaddr-field 130 in the DHCPDISCOVER message 
SI sent by the CPE 18 is already non-zero, (i.e., set by the CM 16) the DHCP 66 proxies leave the 
J!: DHCP 66 giaddr-field 130 intact. 

j ¥ 15 One or more DHCP 66 servers 160 for the selected network host interfaces 162 (e.g., IP 

% 54 interface) associated with the CMTS 12 receive the DHCPOFFER message at Step 310. A 

selected the DHCP 66 server 160 recognizes a DHCP 66 server identifier in the DHCP 66 
sname-field 134 or the IP 54 address that was sent in the DHCPOFFER message in the DHCP 66 
yiaddr-field 126 from the DHCPREQUST message for the selected the DHCP 66 server 160. 
20 The selected DHCP 66 server 160 associated with network host interface 162 selected 

by the CPE 18 in the DHCPREQUEST message creates and sends a DHCP 66 acknowledgment 
message ("DHCPACK") to the CMTS 12 at Step 312 using the DHCP 66 giaddr-field 130. The 
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DHCPACK message is sent with the message fields set as illustrated in Table 9. However, other 
field settings can also be used. The DHCP 66 yiaddr-field contains the IP 54 address for the 
selected network host interface 162 available on the CMTS 12 for receiving data packets from 
data network 28 for CPE 18. 
5 At Step 314, the CMTS 12 receives the DHCPACK message, the CMTS 12 examines 

the DHCP 66 giaddr-field 130 and looks up that IP 54 address in its ARP table or other routing 
tables for an associated MAC 44 address. This is a MAC 44 address for the CM 16, which sent 
the DHCPREQUEST message from CPE 18. The CMTS 12 uses the MAC 44 address 
associated with the DHCP 66 giaddr-field 130 and the DHCP 66 yiaddr-field 126 to update its 
"2 10 routing and ARP tables reflecting this address pairing at Step 316. At Step 318, the CMTS 12 
il sends the DHCPACK message on a downstream channel on cable network 14 to the IP 54 and 
W MAC 44 addresses, respectively (i.e., to the CM 16). If the BROADCAST bit in the DHCP 66 
M flags-field 122 is set to one, the CMTS 12 sends the DHCPACK message to a broadcast IP 54 
Jf; address (e.g., 255.255.255.255), instead of the address specified in the DHCP 66 yiaddr-field 

nj 15 126. the CMTS 12 uses the MAC 44 address associated with the DHCP 66 chaddr-field 130 
% even if the BROADCAST bit is set. 

The CM 16 receives the DHCPACK message. The CM 16 examines the DHCP 66 
yiaddr-field 126 and DHCP 66 chaddr-field 132, and updates its routing table and ARP tables to 
reflect the address pairing at Step 320. At Step 322, the CM 16 sends the DHCPACK message 
20 to CPE 18 via the CMCI 20 at the IP 54 and the MAC 44 addresses respectively from its routing 
tables. If the BROADCAST bit in the DHCP 66 flags-field 122 is set to one, the CM 16 sends 
the downstream packet to a broadcast IP 54 address (e.g., 255.255.255.255), instead of the 
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address specified in the DHCP 66 yiaddr-field 126. The CM 16 uses the MAC 44 address 
specified in the DHCP 66 chaddr-field 132 even if the BROADCAST bit is set to locate the CPE 
18. At Step 324, CPE 18 receives the DHCPACK from the CM 16 and has established a virtual 
connection to data network 28. 
5 In the event that the CPE 1 8 is not compatible with the configuration received in the 

DHCPACK message, the CPE 18 may also generate a DHCP 66 decline ("DHCPDECLINE") 
message and send it to the CM 16. The CM 16 will transmit the DHCPDECLINE message up 
the PPP 50 link via the PSTN 22 to TRAC 24 or the CMTS 12 via an upstream cable channel. 
On seeing a DHCPDECLINE message the TRAC 24 sends a unicast copy of the message to the 

§ 10 CMTS 12. the CM 16 and the CMTS 12 examine the DHCP 66 yiaddr-field 126 and the DHCP 
66 giaddr-field 130, and update their routing and ARP tables had routing tables to flush any 

hi invalid pairings. 

Sf Upon completion of Methods 266 and 292, the CM 16 and the CMTS 12 have valid 

IP/MAC address pairings in their routing and ARP tables. These tables store the same set of IP 
|; 15 54 addresses, but does not associate them with the same MAC 44 addresses. This is because the 
% CMTS 12 resolves all the CPE 1 8 IP 54 addresses to a MAC 44 address of a corresponding the 
CM 16. The CMs 16, on other hand, is able to address the respective MAC 44 addresses of their 
own CPEs 18. This also allows the DHCP 66 clients associated with the CPE 18 to function 
normally since the addressing that is done in the CM 16 CM 16 and the CMTS 12 is transparent 
20 to CPE 18 hosts. 

FIG. 17 is a block diagram illustrating a message flow 326 for Methods 268 and 294 in 
FIGS. 15A, 15B, and 16A and 16B. Message flow 326 illustrates a message flow for Methods 
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268 and 294, for a data-over-cable system with and without telephony return. In another 
embodiment of the present invention, the CM 16 forwards requests from CPE 18 via an upstream 
connection on cable network 14 to the DHCP servers 160 associated with one or more network 
host interfaces 162 associated with the DHCP proxies 158 are not used on the CMTS 12. In such 
5 an embodiment, the TRAK 24 and the DHCP proxies 158 are not used. 

Method 268 and 294 accomplishes resolving addresses for network interface hosts from 
customer premise equipment in a data-over-cable with or without telephony return without 
extensions to the existing DHCP protocol. Methods 268 and 294 of the present invention are 
illustrated in data-over-cable system 10 with telephony return. However, the present invention is 

;i 10 not limited to data-over-cable system 10 with telephony return and can be used in data-over- 

Ll cable system 10 without telephony return by using an upstream cable channel instead of an 

yy upstream telephony channel 

Completing initialization of a cable modem or CPE 

Jf; After obtaining an IP 54 address via DHCP 66, the CM 16 receives a configuration file 

;: %Z 

; :; f is from a configuration file server. Information about the configuration file is included in the 
% DHCPACK message (e.g. 5 Table 9). For example, in one preferred embodiment of the present 
invention, a network address (e.g., an IP 54 address) for the server is included in a DHCP 66 
siaddr-field 128 (FIG. 6), and a name of the configuration file in a DHCP 66 file-field 136. The 
configuration file includes multiple configuration parameters used to initialize the CM 16. The 
20 TFTP 64 server obtains the requested configuration file and sends it to the CM 16. In one 

embodiment of the present invention, the configuration file is obtained by the TFTP 64 server 
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from the DHCP server 160. In another embodiment of the present invention, the configuration 
file is obtained by the TFTP 64 server from the CMTS 12. 

Configuration information from an exemplary configuration file is illustrated in 
Type/Length/Value ("TLV") format in Table 10. However, more or fewer configuration 
5 parameters could also be used. In addition, only an exemplary description of the Value in the 
TLV format is included since the actual numbers used for the Value fields are implementation 



specific. 





Tvoa 


Length 


Value 


Notes 




4x 


6 


Variable 


Header Length 




41 


1 


1 


Class-Of-Service-1 




42 


4 


1,500,000 


Maximum 

downstream data rate 










of 1 .5 Mbps 




43 


4 


256,000 


Maximum upstream 
data rate of 256 Kbps 




44 


1 


5 


Priority is level 5. 




45 


4 


8,000 


Minimum upstream 
data rate of 8 Kbps 




47 


1 


1 


Privacy enabled 




171 


4 


1 


Authorize timeouts 




3 


1 


1 


Enable network 
access 




8x 


8 


Variable 


Vendor ID 




83 


N 


Variable 


N-bytes of vendor 
specific data in TLV 
format 




0 


N 


N-byte padding 


Padding to make 
message 4-byte 
aligned 




255 


N/A 




End-of-file 



Table 10. 



The CPE 18 may also receive a configuration file, if necessary from the CM 16, the 



10 CMTS 12, or the DHCP server 160 via the TFTP 64 server. The CPE 18 also receives 



information on where to find a configuration file, if necessary, in a DCHPACK message. 
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However, the CPE 18 may also receive information on where to find a configuration file with 
other messages (e.g., MAC 44) from the CM 16 or the CMTS 12. 

After receiving a configuration file, the CM 16 sends a registration message to the CMTS 
12. The registration message is typically a MAC 44 management message that includes a MAC 
5 44 management header and selected information from the configuration file (e.g., from Table 10) 
in TLV format. The registration message is sent by the CM 16 to the CMTS 12 within a pre- 
determined time after receiving a DHCPACK to provide a security measure to protect the data- 
over-cable system 10. If the registration message is not sent by the CM 16 to the CMTS 12 
within the pre-determined time, the CMTS 12 purges its ARP and routing tables of entries 

5 10 including the IP 54 address obtained by the CM 16 with DHCP 66. This helps prevent a rogue 

1; CM 1 6 from registering with the CMTS 12. 

y j If a data-over-cable system with telephony return is being used, the registration message 

^ is sent on an upstream telephony channel with PPP 50 via the PSTN 22 and TRAC 24 to the 

CMTS 12. If a data-over-cable system without telephony return is being used, the registration 
:X 15 message is sent on an upstream cable channel to the CMTS 12. 

m Upon receiving the registration message from the CM 16, the CMTS 12 updates its 

routing and ARP tables to reflect a CM 16 IP 54/MAC 44 address pairing in the registration 
message. The CMTS 12 will generate an SNMP 62 trap if an IP 54 address in the registration 
message is paired with a different MAC 44 address for the CM 16 in the CMTS 12 tables. As is 
20 known in the art, an SNMP 62 trap is used to indicate an error condition in a network. As was 
discussed above, the CMTS 12 records an IP 54 address obtained by the CM 16 with DHCP 66 
before it forwards the DHCPACK to the CM 16. 
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The CMTS 12 sends a registration response back to the CM 16 that also includes CPE 18 
IP 54 addresses in the CMTS 12 routing and ARP tables which are associated with a MAC 44 
address for the CM 16, if any. However, depending on the initialization sequence, the CPE 18 
may not have obtained an IP 54 address with DHCP 66 yet. The registration response message is 
5 also typically a MAC 44 management message with MAC 44 management header and TLV 
encoded data for the CM 16 (e.g., CMTS 12 data or vendor specific data). 

The CM 16 may also proxy ARP for any CPE 18 IP 54 addresses in a registration 
response message. The CM 16 will use ARP on the CMCI 20 (FIG. 1) for the hardware 
addresses of the CPE 18 IP 54 addresses and update routing and ARP tables on the CM 16. 
^ 10 The CPE 1 8 may also send a registration message to the CMTS 12 via the CM 16, and 

12 ma y also receive a registration response from the CMTS 12 via the CM 16. If the CPE 18 sends 

y a registration message, both the CM 16 and the CMTS 12 update ARP and other routing tables. 

SJ The CMTS 12 will update its routing and ARP tables to reflect a CPE 18 IP 54 addresses and the 

^ CM 16 MAC 44 address pairing in the registration request. As was discussed above, the CMTS 

j| 15 12 records an IP 54 address obtained by the CPE 18 with DHCP 66 before sending a DHCPACK 
1 for the CPE 1 8 to the relay agent, the CM 1 6. The CMTS 1 2 will also generate an SNMP 64 

trap if a CPE 1 8 IP 54 address in the registration request is paired with a different MAC 44 
address for the CM 16 in the CMTS 12 tables. 

After registration, if a data-over-cable system without telephony returned is being used, 
20 the CM 16 sends messages to the CMTS 12 on an upstream cable channel and receives messages 
from the CMTS 12 on a downstream cable channel. The CM 16 can also send data packets on an 
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upstream cable channel to the CMTS 12, which forwards the data packets to the data network 28. 
The CMTS 12 sends response data packets back to the CM 16 on a downstream cable channel. 

If a data-over-cable system with telephony return is used, after registration the CM 16 
can send messages to the CMTS 12 on an upstream telephony channel via the PSTN 22 to the 
5 TRAC 24, which forwards the messages to the CMTS 12. The CM 16 can also send data packets 
on an upstream telephony channel via the PSTN 22 to the TRAC 24, which forwards the data 
packets to the data network 28. The CMTS 12 sends response data packets back to the CM 16 
on a downstream cable channel. 

After completing the registration request and registration response sequence, the CM 16 
J=f 10 and/or the CPE 1 8 have completed initialization and can communicate with the data-over-cable 
^ system 10 and the data network 28 (FIG. 1). The CM 16 typically acts as a relay agent for 

y requests and responses for one or more CPEs 18 attached to the CM 16. 

SI Dynamic service registration in a data-over-cable system 

^ As was discussed above, it is desirable to dynamically provide deferred session based 

15 services after a session has been established between a network device (e.g., the CM 16 or the 
g 5J CPE 18) and the data-over-cable system 10. The dynamic session based services should provide 

the ability to activate new session-based services and also allow authentication, authorization or 
accounting event to be dynamically generated after a session between a network device and a 
data-over-cable system has already been established. 
20 FIG. 18 is a flow diagram illustrating a Method 330 for dynamic service registration on a 

data-over-cable system. Method 330 includes receiving a first message on a second network 
device on a data-over-cable system from a first network device on the data-over-cable system at 
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Step 332. The first message includes multiple service parameters for a desired service for a 
service device associated with the first network device. At step 334, the multiple service 
parameters for the desired service are extracted from the first message. At step 336, a service 
session profile is created for the desired service. The service session profile includes one or 
5 more of the extracted service parameters required by the desired service. The service session 
profile is used by a service server associated with the second network device to activate the 
desired service. At Step 338, the service session profile is associated with a deferred inactive 
service identifier for the first network device. The deferred service identifier is used to activate 
the desired service at a later time. At Step 340, the deferred inactive service identifier is returned 
^ 10 to the first network device in a second message. 

The deferred inactive service identifier is used at a later time by a service device 
yj associated with the first network device to dynamically activate the desired service and to 

%J generate a service event on a service server. The desired service can be dynamically activated 

H even though the first network device may have already established a session (e.g., a login) with 

^ 15 the second network device on the data-over-cable system. Multiple deferred inactive service 
r? identifiers can also be returned to the first network device to support multiple desired services for 

multiple service devices associated with the first network device. 

In one exemplary preferred embodiment of the present invention, the first network device 
is the CM 16, and the second network device is the CMTS 12. The first message is a registration 
20 message and the second message is registration response message. The service parameters 
include of Quality-of-Service ("QoS"), Class-of-Service ("CoS"), Type-of-Service ("ToS"), 
voice service parameters or other service session parameters. The deferred inactive service 
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identifier is a MAC 44 Service IDentifier ("SID") and the service session profile describes the 
desired service associated with the MAC 44 deferred inactive SID. The MAC 44 deferred 
inactive SID is used at a later time by a service device associated with the CM 16 to activate the 
desired service and to generate a service event (e.g., authentication, authorization or accounting) 
5 on a service server. However, the present invention is not limited to the network devices, 

messages, service parameters, or deferred service identifiers described. Other network devices 
(e.g., CPE 18), messages (e.g., DHCP 66), service parameters or deferred service identifiers 
could also be used. 

In one embodiment of the present invention, at Step 332, the CMTS 12 receives a 
10 registration message from the CM 16. The registration message includes multiple service 
*CL parameters (e.g., QoS) for a desired service (e.g., Voice over Internet Protocol ("VoIP") for one 

yj or more service devices (e.g., a VoIP telephone) associated with the CM 16. 

H FIG. 19 is a block diagram illustrating a registration message 342 sent from the CM 16 to 

Jf: the CMTS 12. The registration message includes a MAC 44 management header-field 344, an 

=^ 15 initialization SID-field 346 and a TLV encoded information-field 348. An initialization SID in 
g the initialization SID-field 346 is a SID used by the CM 16 to request bandwidth from the CMTS 

12. In a preferred embodiment of the present invention, the CM 16 encodes service parameters 
required for one or more desired services and capabilities for service devices associated with the 
CM 16 in TLV format and places them in the TLV encoded information-field 348. For example, 
20 a CM 16 desiring to user VoIP will encode encode VoIP service parameters in TLV format. In 
addition, VoIP service devices associated with the CM 16 including voice and/or video 
coder/decoders ("codecs"), will have capabilities of the VoIP codecs encoded in TLV format. 
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The TLV encoding information is placed in the TLV encoded-information field 348 in the 
registration message 342. 

Returning to FIG. 18 at step 334, the multiple service parameters for the desired service 
are extracted from the first message. At step 336, a service session profile is created for the 
5 desired service. The service session profile includes one or more of the extracted service 
parameters required by the desired service. The service session profile is used by a service 
server (e.g., a VoIP server) associated with the CMTS 12 to activate the desired service. Table 
1 1 illustrates an exemplary service session profile layout. However, other service session profile 
layouts can also be used and the present invention is not limited to the service session profile 
10 layout illustrated in Table 1 1 . 



Service 


Service Device 
Type 


Service 
Parameter-1... 


Service 
Parameter-N 


VoIP 


VoIP Telephone 


QoS-3 


32-bit codec 



Table 11. 



|U Returning again to FIG. 18 at Step 338, the service session profile is associated with a 

F MAC 44 deferred inactive Service IDentifier ("SID") for the CM 16. 

to 1 5 A MAC 44 deferred inactive SIDs defines a particular mapping between the CM 1 6 and 

the CMTS 12. This mapping is the basis on which bandwidth is typically allocated to the CM 16 
by the CMTS 12 and by which service parameters such as QoS, CoS and ToS are implemented. 
Within a MAC 44 sublayer domain, MAC 44 deferred inactive SIDs are unique. 

In one preferred embodiment of the present invention, the CMTS 12 assigns one or more 
20 MAC 44 deferred inactive SIDs to each CM 16, corresponding to services requested by service 
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devices associated with the CM 16. In one preferred embodiment of the present invention, a 
single MAC 44 deferred inactive SID can be used, for example, to offer "best-effort" services. 
However, MAC 44 deferred inactive SIDs for a preferred embodiment of the present invention 
can also provide more complex servers to be developed for the CM 16 with support for multiple 
5 classes of services while still supporting interoperability with more basic services such as "best- 
effort." For example, the MAC 44 deferred inactive SIDs can support "data flows" on which 
protocols such as Resource ReSerVation Protocol ("RSVP") and Real-Time Protocol ("RTP") 
are based. For more information on RSVP see, RFC-2205, incorporated herein by reference. 
For more information on RTP see, RFC-1889, incorporated herein by reference, 
y 10 "Normal" MAC 44 SIDs typically have values in the range of zero through 0x3FFF (i.e., 

[T 0 through 16,3 83). In one preferred embodiment of the present invention, this range of values is 

y j split into pre-determined sub-ranges ranges including, for example, a first sub-range for 
SJ "normal" MAC 44 SIDs, (e.g., 0-2047) a second sub-range for MAC 44 deferred inactive SIDs, 

M (e.g., 2048-8191) and a third sub-range for MAC 44 deferred active SIDs (e.g., 8191-16,382). 

I y 15 MAC 44 deferred active SIDs are explained below. 

J In another preferred embodiment of the present invention, the range of values is split into 

two sub-ranges, a first sub-range for MAC 44 deferred inactive SIDs (e.g., 8192-16,382) and a 
second sub-range for MAC 44 deferred active SIDs including "normal" MAC 44 SIDs (e.g., 0- 
8191). Returning again to FIG. 18, the MAC 44 deferred inactive SID is returned to the first 
20 network device in a registration response message at Step 340. The registration response 

message includes one or more MAC 44 deferred inactive SIDs encoded in TLV format. A MAC 
44 deferred inactive SID is returned for each deferred service requested by a service device 
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associated with the CM 16. Thus, multiple MAC 44 deferred inactive SIDs may be returned to a 
CM 16. 

FIG. 20 is a block diagram illustrating a registration response message 350 sent from the 
CMTS 12 to the CM 16. The registration response messages 350 includes a MAC 44 
5 management header-field 352, response SID-field 354, a response-field 356, and a TLV encoded 
information-field 358. The response SID-field 354 includes the MAC 44 SID from the 
registration request message 342 to which the registration response refers (i.e., the SID from the 
initialization SID-field 346 (FIG. 19). The response-field 356 includes a response value (e.g., 
zero = ok, 1 = authentication failure, 2 = service failure, etc.). 
¥ 10 The TLV encoded information-field 358 includes service device capabilities, service 

12 class data including the MAC 44 deferred inactive SID, service not available data, vendor 
hi specific data, and other data. Table 12 illustrates exemplary TLV data types included in the TLV 
SI encoded information-field 358. However, more or fewer TLV data types may also be included 
H; in the TLV encoded information-field 358, and the present invention is not limited to the TLV 

J y 15 data illustrated in Table 12. 



Service Parameter 


Description 


Service Device Capability Data 


Service capabilities of service devices associated 
with the CM 16. 


Service Data 


Includes a MAC 44 deferred inactive SID for each 
deferred type of deferred service granted. 


Service Not Available Data 


If a service cannot be supported, this configuration 
setting is returned in place of the service class 
data. If this is received, the entire registration 
request is considered to have failed and must be 
repeated. 


Vendor Specific Data 


Vendor ID Configuration Settings including vendor 
ID of the CMTS 12 and vendor-specific extensions. 




fable 12. 
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Dynamic service activation in a data-over-cable system 

The MAC 44 deferred inactive SID from Method 330 is used at a later time by a service 
device (e.g., VoIP telephone) associated with a network device, such as the CM 16, to activate 
the desired service and to generate a service event (e.g., authentication, authorization or 
5 accounting) on a service server (e.g., VoIP server). 

FIG. 21 is a flow diagram illustrating a Method 360 for dynamic service activation on the 
data-over-cable system 10. Method 360 includes at Step 362, receiving a service request from a 
first network device on a second network device on a data-over-cable system to activate a 
desired service. The service request includes a deferred inactive service identifier sent to the first 
y 10 network device by the second network device. The service request is initiated by a service device 
!^ associated with the first network device. At Step 364, the desired service is activated on the 

yj data-over-cable system using a service session profile associated with the deferred inactive 

Sj service identifier creating during registration of the first network device with the second network 

device. At Step 366, the deferred inactive service identifier is changed into a deferred active 
15 service identifier in the data-over-cable system. The second network device maintains a 
r! mapping between deferred inactive service identifier values and deferred active service identifier 

values. This mapping also allows an inactive service indicated by a deferred inactive service 
identifier to be activated, and an active service indicated by a deferred active service identifier to 
be deactivated. An active or inactive service is indicated by a pre-determined service identifier 
20 valve. At Step 368, a service event is generated on a service server associated with the data- 
over-cable system to request activation of the desired service. 

-70- 

MCDONNELL BOEHNEN 
HULBERT & BERGHOFF 
300 SOUTH WACKER DRIVE 
CHICAGO, ILLINOIS 60606 
TELEPHONE (312) 913-0001 



In one exemplary preferred embodiment of the present invention, the first network device 
is the CM 16, and the second network device is the CMTS 12. The deferred inactive service 
identifier and the deferred active service identifier are MAC 44 SIDs and the service session 
profile describes the desired service based on the MAC 44 SID. The service event (e.g., 
5 authentication, authorization or accounting) is generated on a service server. However, the 

present invention is not limited to the network devices, messages, service parameters, or deferred 
service identifiers described. Other network devices (e.g., CPE 18), messages (e.g., DHCP 66), 
service parameters or deferred service identifiers could also be used for other preferred 
embodiments of the present invention. 
^ 10 In one exemplary preferred embodiment of the present invention, at Step 362, a service 

|T request is received on the CMTS 12 from the CM 16 to activate a desired service. The service 
yj request includes a MAC 44 deferred inactive SID sent to the CM 16 by the CMTS 12. The 
SI service request is initiated by a service device associated with the first network device. For 

[f; example a VoIP telephone associated with the CM 16 may send an "offhook" request via the CM 

15 1 6 to the CMTS 12 to activate VoIP service with service parameters sent to the CMTS 12 in a 
g registration message (e.g., Step 332 of Method 330, FIG. 18). The offhook request would 

include a MAC 44 deferred inactive SID sent to the CM 16 in a registration response message 
(e.g., at Step 340, Method 330, FIG. 18) and saved in a service session profile. However, other 
service requests may also be made and the present invention is not limited to VoIP requests. 
20 Returning to FIG. 21 at Step 364, the desired service (e.g., VoIP) is activated on the data- 

over-cable system using a service session profile (e.g., VoIP service session profile from Table 
1 1) associated with the MAC 44 deferred inactive SID. At Step 366, the MAC 44 deferred 
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inactive SID is changed into a MAC 44 deferred active SID in the data-over-cable system. The 
MAC 44 deferred active SID indicates the desired service (e.g., VoIP) associated with the MAC 
44 deferred inactive SID is now active. In one exemplary preferred embodiment of the present 
invention, changing the MAC 44 deferred inactive SID into a MAC 44 deferred active SID 
5 includes changing the value of the MAC 44 deferred inactive SID into a new value indicating a 
MAC 44 deferred active SID. The CMTS 12 maintains a mapping between the MAC 44 
deferred inactive SID values and MAC 44 deferred active SIDs values. This mapping allows an 
active service indicated by a MAC 44 deferred active SID to be deactivated and an inactive 
service indicated by a MAC 4 deferred inactive SID to be activated. An active or inactive 
y 10 service is indicated by a pre-determined MAC 44 SID valve. 

rf Table 13 illustrates an exemplary mapping layout maintained by the CMTS 12 for MAC 

yd 44 deferred SID's. However, the mapping illustrated in Table 12 is exemplary, and other 

H mapping layouts could also be used. The present invention is not limited to the mapping 

^ illustrated in Table 1 3 . 



Cable Modem 


Service 


MAC 44 deferred inactive SID 


MAC 44 deferred active SID 


CM-1 MAC 44 
Address 


VoIP 


2048 


8191 


CM-2 MAC 44 
Address 


ATM 


2049 




CM-2 MAC 44 
Address 


Frame Relay 


2050 













As is illustrated in Table 13, the VoIP service for the CM 16 number- 1 is active, as it has an 



assigned MAC 44 deferred active SID value of 8191, indicating the VoIP service is now active 
(e.g., assigned at Step 366 of Method 360). The other two services, ATM and Frame Relay for 
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the CM 16 number-2, have been assigned MAC 44 deferred inative SIDs of 2049 and 2050. 
However, neither the ATM or frame relay services have been activated by a service device 
associated with the CM 16 number-2 (i.e., Table 13 does not yet include a MAC 44 deferred 
active SID for theses MAC 44 deferred inactive SIDs). If the VoIP service for the CM 16 
5 number- 1 is deactivated (e.g., at Step 374 of Method 370) and activated again at a later time 
(e.g., with Method 360), the CMTS 12 may not assign a MAC 44 deferred active SID a valve of 
8191 for the VoIP service. Another value could be assigned depending on how many other 
services have already been activated (e.g., ATM and/or Frame Relay). 

Returning to FIG. 21 at Step 368, a service event is generated on a service server 
"i 10 associated with the data-over-cable system to request activation of the desired service. For 
LI example, an authentication, authorization, or accounting service event is generated on a VoIP 

fjj server associated with the CMTS 12. The service event is mapped to a specific authentication, 

SI authorization, or accounting request on the VoIP server to initiate one or more event services, 

J!" (e.g., a VoIP authentication request, VoIP start accounting request, etc.). Thus, a deferred 

15 inactive service has been activated on the data-over-cable system 10. 
m Dynamic service deactivation in a data-over-cable system 

A service device associated with a CM 16 may also desire to deactivate a desired service 
that was dynamically activated with method 360 (FIG. 21). FIG. 22 is a flow diagram 
illustrating a Method 370 for dynamic service deactivation on data-over-cable system. At Step 
20 372, a service request is received from a first network device on a second network device on a 
data-over-cable system to deactivate a desired service. The service request includes a deferred 
active service identifier. The service request is initiated by a service device associated with the 
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first network device. At Step 374, the desired service is deactivated on the data-over-cable 
system. At Step 376, the deferred active service identifier is changed into a deferred inactive 
service identifier. At Step 378, a service event is generated on a service server associated with 
the data-over-cable system 10 to request deactivation of the desired service. 
5 In one exemplary preferred embodiment of the present invention, the first network device 

is the CM 16, and the second network device is the CMTS 12. The deferred inactive service 
identifier and the deferred active service identifier are MAC 44 SIDs. The service event (e.g., 
authentication, authorization or accounting) is generating on a service server. However, the 
present invention is not limited to the network devices, messages, service parameters, or deferred 
^ 10 service identifiers described. Other network devices (e.g., CPE 18), messages (e.g., DHCP 66), 
12 service parameters or deferred service identifiers could also be used for other preferred 

1 a embodiments of the present invention. 

In one exemplary preferred embodiment of the present invention, at Step 372, a service 
rf; request is received from the CM 16 on a the CMTS 12 on the data-over-cable system 10 to 

! 2 15 deactivate a desired service. The service request includes a MAC 44 deferred active SID. The 
,5 service request is initiated by a service device (e.g., a VoIP telephone) associated with the CM 

16. In one exemplary preferred embodiment of the present invention, the service request is a 
VoIP "onhook" request to terminate a VoIP call. However, other service requests can also be 
made, and the present invention is not limited to VoIP requests. 
20 At Step 374, the desired service (e.g., VoIP ) is deactivated on the data-over-cable system 

10. At Step 376, the MAC 44 deferred active SID is changed into a MAC 44 deferred inactive 
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SID. At Step 378, a service event is generated on a service server associated with the data-over- 
cable system to request deactivation of the desired service. 

For example, an authentication, authorization, or accounting service event is generated on 
a VoIP server associated with the CMTS 12. The service event is mapped to a specific 
5 authentication, authorization, or accounting request on the VoIP server to discontinue one or 
more event services (e.g., a VoIP discontinue authorization, a VoIP stop accounting request, 
etc.). 

Exemplary preferred embodiments of the present invention have been described with 
examples relating to VoIP servers and services. The VoIP servers and services may be used in a 
trs d 10 data-over-cable system with or without telephony return. However, the present invention is not 
12 limited to VoIP services, and other services and service servers may also be used. For example, 
hj part of the Multimedia Cable Network Systems ("MCNS") Data Over Cable Service Interface 
%J Specification system ("DOCSIS") defines server interfaces that provide data services. Virtually 

^ any service server defined by DOCSIS system could be used for preferred embodiments of the 

1 7 15 present invention. 

^ In another preferred embodiment of the present invention, a DOCSIS Authentication Dial 

In User Server ("RADIUS") server can be used as a service server to activate desired services. 
As is known in the art, RADIUS servers are responsible for receiving user connection requests, 
authenticating a user, and then returning configuration information necessary for a client to 
20 deliver service to a user. A RADIUS server can act as a proxy client to other RADIUS servers or 
other kinds of authentication servers (e.g., DHCP server 160, CMTS 12, VoIP server, ATM, 
ISDN, Frame Relay, etc.). For more information on RADIUS see, RFC-2138, incorporated 
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herein by reference. In such an embodiment, the RADIUS server may be associated with TRAC 
24. or may be associated with the CMTS 12. The RADIUS session may be initiated in a data- 
over-cable system with or without telephony return. 

A RADIUS server may be used to allow dial-in services to the cable network 14 via the 
5 CMTS 12 in a data-over-cable system with or without telephony return. A service event to for 
activation or deactivation of a desired service can also be mapped to a specific RADIUS 
authentication, authorization, or accounting request. For example, a RADIUS Accounting 
START request, a RDIUS Accounting STOP request, etc. 

In addition, other service servers not defined by DOCSIS system could also be used to 
10 provide deferred services. For example, Asynchronous Transfer Mode ("ATM") Frame Relay, 
LI Integrated Services Digital Network ("ISDN"), Asymetric Digital Subscriber Lines ("ADSL") 
y and other service servers could also be used to provide deferred services on a data-over-cable 
SJ system 10. 

Jf; Method 330 allows a network device such as a CM 16 or a CPE 18 to use one or more 

! *f 15 deferred services as the network device registers with another network device, such as the CMTS 
JJ. 12. The CMTS 12 returns one or more deferred inactive service identifies that service devices 

associated with a network device can use to dynamically activate a deferred service even after 
the network device has established a service session with the CMTS 12. Methods 360 and 370 
allow a network device with associated service devices to dynamically activate or deactivate one 
20 or more desired services after a network device has registered and created a service session with 
the CMTS 12. The activation and deactivation of desired services is accomplished with the 
cooperation of many different type of service servers. 
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It should be understood that the programs, processes, methods, systems and apparatus 
described herein are not related or limited to any particular type of computer apparatus (hardware 
or software), unless indicated otherwise. Various types of general purpose or specialized 
computer apparatus may be used with or perform operations in accordance with the teachings 
5 described herein. 

In view of the wide variety of embodiments to which the principles of the invention can 
be applied, it should be understood that the illustrated embodiments are exemplary only, and 
should not be taken as limiting the scope of the present invention. For example, the Steps of the 
flow diagrams may be taken in sequences other than those described, and more or fewer 

^ 10 elements or components may be used in the block diagrams. In addition, the present invention 

IJ can be practiced with software, hardware, or a combination thereof 

hj The claims should not be read as limited to the described order or elements unless stated 

-•4 to that effect. Therefore, all embodiments that come within the scope and spirit of the following 

^ claims and equivalents thereto are claimed as the invention. 
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WE CLAIM: 

1. In a data-over-cable system including a plurality of network devices, a method for 
providing dynamic services, comprising the following steps: 

receiving a first message on a second network device on a data-over-cable system from a 
5 first network device on the data-over-cable system, wherein the first message includes a plurality 
of service parameters for a desired service for a service device associated with the first network 
device; 

extracting the plurality of service parameters for the desired service from the first 
message; 

"tJ 10 creating a service session profile for the desired service, wherein the service session 

12 profile includes a one or more of the extracted service parameters required by the desired service, 

Id and wherein the service session profile is used by a session server associated with the data-over- 

Sl cable system to activate the desired service; 

associating the service session profile with a deferred service identifier for the first 
: u 15 network device, wherein the deferred inactive service identifier is used to activate the desired 
S service at a later time; 

returning the deferred inactive service identifier to the first network device in a second 
message. 

20 2. A computer readable medium having stored therein instructions for causing a central 

processing unit to execute the method of Claim 1. 
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3. The method of Claim 1 wherein the first network device is a cable modem and the 
second network device is a cable modem termination system. 



4. The method of Claim 1 wherein the deferred inactive service identifier is a Medium 
5 Access Control Protocol service identifier. 

5. The method of Claim 1 wherein the service parameters include any of quality-of- 
service, class-of-service ? type-of-service or voice service parameters. 

y 10 6. The method of Claim 1 wherein the first message is a registration message and the 

lI second message is a registration response message. 

M 7. The method of Claim 1 wherein the step of returning the deferred inactive service 

t! identifier to the first network device in a second message includes returning the deferred inactive 

15 service identifier to the first network device encoded in a Type-Length-Value format in the 

m second message. 

8. The method of Claim 1 further comprising: 

receiving a service request from the first network device on the second network device to 
20 activate a desired service, wherein the service request includes the deferred inactive service 

identifier sent to the first network device, and wherein the service request is initiated by a service 
device associated with the first network device; 
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activating the desired service on the data-over-cable system using the service session 
profile associated with the deferred inactive service identifier; 

changing the deferred inactive service identifier into a deferred active service identifier; 

and 

5 generating a service event on a service server associated with the data-over-cable system 

to request activation of the desired service. 

9. The method of Claim 8 wherein the service server is any of a Remote Authentication 
Dial In User Server, a Voice over Internet Protocol server, Asynchronous Transport Mode 
Server, Frame Relay Server, or an Integrated Services Digital Network server, or an Asymetric 
Digital Subscriber Line server. 

10. The method of Claim 8 wherein the step of generating a service event includes 
generating any of an authentication, authorization or an accounting event. 

11. The method of Claim 1 further comprising: 

receiving a service request from the first network device on the second network device to 
deactivate a desired service, wherein the service request includes a deferred active service 
identifier, and wherein the service request is initiated by a service device associated with the first 
20 network device; 

deactivating the desired service on the data-over-cable system; 
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changing the deferred active service identifier into a deferred inactive service identifier; 

and 

generating a service event on a service server associated with the data-over-cable system 
to request deactivation of the desired service. 

5 

12. In a data-over-cable system including a plurality of network devices, a method for 
providing dynamic services, comprising the following steps: 

receiving a service request from a first network device on a second network device on a 
data-over-cable system to activate a desired service, wherein the service request includes a 
O 10 deferred inactive service identifier sent to the first network device by the second network device, 
12 and wherein the service request is initiated by a service device associated with the first network 
i s ] device; 

SJ activating the desired service on the data-over-cable system using a service session 

M* profile associated with the deferred inactive service identifier created during a registration of the 

^ 15 first network device with the second network device; 

!f? changing the deferred inactive service identifier into a deferred active service identifier; 

and 

generating a service event on a service server associated with the data-over-cable system 
to request activation of the desired service. 

20 

13. A computer readable medium having stored therein instructions for causing a central 
processing unit to execute the method of claim 12. 
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14. The method of Claim 12 wherein the first network device is a cable modem and the 
second network device is a cable modem termination system. 

5 15. The method of Claim 12 wherein the deferred inactive service identifier is a Medium 

Access Control Protocol service identifier and the deferred active service identifier is a Medium 
Access Control Protocol Service identifier. 

16. The method of Claim 12 wherein the service parameters include any of quality-of- 
O 10 service, class-of service, type-of service or voice service parameters. 

17. The method of Claim 12 wherein the step of generating a service event includes 
generating any of an authentication, authorization or an accounting event. 

18. The method of Claim 12 wherein service server is any of a Remote Authentication 
Dial In User Server, a Voice over Internet Protocol server, Asynchronous Transport Mode 
Server, Frame Relay Server, an Integrated Services Digital Network server, or an Asymetric 
Digital Subscriber Line server. 

19. The method of Claim 12 wherein the service request is a Voice over Internet 
Protocol offhook request. 



-82- 



MCDONNELL BOEHNEN 
HULBERT & BERGHOFF 
300 SOUTH WACKER DRIVE 
CHICAGO, ILLINOIS 60606 
TELEPHONE (312) 913-0001 



20. In a data-over-cable system including a plurality of network devices, a method for 
providing dynamic services, comprising the following steps: 

receiving a service request from a first network device on a second network device on a 
data-over-cable system to deactivate a desired service, wherein the service request includes an 
5 active service identifier, and wherein the service request is initiated by a service device 
associated with the first network device; 

deactivating the desired service on the data-over-cable system; 

changing the deferred active service identifier into a deferred inactive service identifier; 

and 

s ^ 10 generating an event on a service server associated with the data-over-cable system to 

request deactivation of the desired service. 

21 . A computer readable medium having stored therein instructions for causing a central 
processing unit to execute the method of laim 20. 

22. The method of Claim 20 wherein the deferred active service identifier is a Medium 
Access Control Protocol service identifier and the deferred inactive service identifier is a 
Medium Access Control Protocol service identifier. 

20 23. The method of Claim 20 wherein the service request is a Voice over Internet 

Protocol onhook request. 
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24. In a data-over-cable system including a plurality of network devices, a method for 
providing dynamic services, comprising the following steps: 

sending a service request from a first network device on a data-over-cable system to a 
second network device on the data-over-cable system to activate a deferred inactive service, 
5 wherein the service request includes an deferred inactive service identifier sent to the first 

network device by the second network device that is used to activate a deferred inactive service, 
and wherein the service request is initiated by a service device associated with the first network 
device; and 

receiving a service notification from a service server associated with the second network 
^ 10 device indicating that the deferred inactive service has been activated by the second network 
|I device. 

Nf 25. A computer readable medium having stored therein instructions for causing a central 

lH processing unit to execute the methods of Claim 24. 

IS 15 

ff\ 26. In a data-over-cable system including a plurality of network devices, a method for 

providing dynamic services, comprising the following steps: 

sending a service request from a first network device on a data-over-cable system to a 
second network device on the data-over-cable system to deactivate a desired service, wherein the 
20 service request includes an deferred active service identifier created from a deferred inactive 
service identifier sent to the first network device by the second network device, and wherein the 
service request is initiated by a service device associated with the first network device; and 
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receiving a service notification from a service server associated with the second network 
device indicating that the deferred active service has been deactivated by the second network 
device. 

5 27. A computer readable medium having stored therein instructions for causing a central 

processing unit to execute the method of Claim 26. 

28. A system for providing dynamic services to a network device in data-over-cable 
system, comprising in combination: 
5j S lo a network device for providing a desired service requested by a service device; 

ji a service session profile including one or more of the service parameters required for a 

kj desired service and used by a service server associated with a data-over-cable system for 
^ activating the desired service; 

^ a deferred inative service identifier associated with the service session profile for 

12. 15 allowing activation of a desired service; 

m a deferred active service identifier created from a deferred inactive service identifier for 

indicating that a desired service is active; and 

a service event generator for generating a service event on a service server to request a 
change in status of a desired service on a data-over-cable system. 
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29. In a data-over-cable system including a plurality of network devices, a method for 
providing dynamic services, comprising the following steps: 

receiving a registration message on cable modem termination system on data-over-cable 
system from a cable modem on the data-over-cable system, wherein the registration message 
5 includes a plurality of service parameters for one or more desired services for one or more 
service devices associated with the cable modem; 

extracting the plurality of service parameters for the one or more desired services from 
the registration message; 

creating one or more service session profiles for the one or more desired services, 
10 wherein the service session profiles include one or more of the extracted service parameters 

required by the one or more desired services and wherein the service session profiles are used by 
session servers associated with the data-over-cable system to provide the one or more desired 
services with required parameters; 

associating the one or more service session profiles with one or more deferred inactive 
15 medium access control protocol service identifiers, wherein the one or more deferred inactive 
medium access control protocol service identifiers are used to activate the one or more desired 
services at a later time; and 

returning the one or more deferred inactive medium access control service identifiers to 
cable modem in a registration response message, 
20 wherein the deferred medium access control service identifiers are used to cause 

activation of the one or more desired service by one or more service devices associated with the 
cable modem, and 
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wherein the deferred medium access control service identifiers are used to generate 
events to request a change in status in one or more desired services on one or more service 
servers associated with the cable modem termination system. 

5 30. A computer readable medium having stored therein instructions for causing a central 

processing unit to execute the method of Claim 29. 
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ABSTRACT OF THE DISCLOSURE 
A method and system for dynamic service registration, activation and deactivation on a 
data-over-cable system. A first network device, such as a cable modem with associated service 
devices (e.g., Voice over Internet Protocol telephones) sends a first message to another network 
5 device, such as a cable modem termination system. The first message includes multiple service 
parameters for a desired service requested by a service device associated with the first network 
device. The multiple service parameters are extracted from the first message. A service session 
profile is created for the desired service. The service session profile includes one or more of the 
extracted service parameters required by the desired service. The service session profile is used 
S 10 by a service server associated with the cable modem termination system to provide a desired 
il service. The service session profile is associated with a deferred inactive service identifier for 
yJ the cable modem. The deferred inactive service identifier is returned to the cable modem in a 
^ second message. The deferred inactive service identifier is used at a later time by a service 
l! device associated with the cable modem to activate the desired service and to generate a service 
nl' 15 event on a service server. The service event may include an authentication, authorization, 
m accounting or other event. A deferred service can be activated and deactivated used even after a 
network device, such as a cable modem, has already established a session with another network 
device, such as a cable modem termination system, on a data-over-cable system. 
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